トップページunix
1001コメント305KB

シェルスクリプト総合 その14

■ このスレッドは過去ログ倉庫に格納されています
0001名無しさん@お腹いっぱい。2009/01/29(木) 06:54:48
シェルスクリプトの総合スレです。
スクリプトのお勉強・自慢・腕試しなどにどうぞ。
まずは注意点、リンク、地鎮祭など(>>1-6くらい)をご覧ください。


□お約束
・特記なき場合はBourne Shell(/bin/sh)がデフォルトです。
 bash/zsh/ksh/ashなどに依存する場合は明示しましょう。
 Linuxユーザは/bin/shの正体がbashなので特に注意。
FreeBSDユーザは/bin/shの正体がashなので注意。
v7 shに一番近くて、現役のshは、OpenSolaris由来のheirloom sh。
http://src.opensolaris.org/source/xref/onnv/onnv-gate/usr/src/cmd/sh/
http://heirloom.sourceforge.net/sh.html
・csh/tcshのシェルスクリプトは推奨されません。
(理由は「csh-whynot」でググれ)
・UNIXにはシェルスクリプトに便利な小さなコマンドがいろいろあります。
 manや参考リンクを見ましょう。
 aproposないしはman -kでそれらしい単語による簡単な検索もできます。
・シェルスクリプトのことをシェルってゆーな
・シェルで使えるワイルドカード等は正規表現ではありません。
正規表現の話題はスレ違い(正規表現スレへ)

□初心者へのアドバイス:
・適した道具を判断するのも頭の重要な使い方。シェルスクリプトよりも
 RubyやPerlの方が適した仕事には素直にそちらを使いましょう。
・知らないコマンドが出てきたらmanを引きましょう。
・思い通りに動かないときは、まずは sh -x でトレースしましょう。

前スレ落ちたみたいなのでリンク省略。
0525名無しさん@お腹いっぱい。2009/04/20(月) 07:25:46
>>524
不用意な展開を防ぐため。

基本はすべてシングルクォート。
$HOGE とか `com` とか、展開が必要な時のみダブルクォート、というのがルール。
0526名無しさん@お腹いっぱい。2009/04/20(月) 07:44:04
>>525
さんくす
もっといっぱい本を読んで、写経します
0527名無しさん@お腹いっぱい。2009/04/20(月) 09:31:41
>>519
kshの速さを実感して貰えて何より。
いまいちマイナーなのが不思議だったりする。
0528名無しさん@お腹いっぱい。2009/04/20(月) 12:48:18
kshは商用SystemV系ってイメージあるし
0529名無しさん@お腹いっぱい。2009/04/20(月) 12:58:57
>>527
昔はこぞってみんな使ってたんだぜ。
bashがなかった時代だけど。
0530名無しさん@お腹いっぱい。2009/04/20(月) 13:16:27
>>525
自分ルールを標準のごとく言ったりエレガントとか言うのはどうかと思う
520〜523までなら後から見たときや他人が書いたものを見たとき520が一番見やすい

echo の内容を | を通して渡す為に >>523 にしたというならともかく(この場合でも他に方法はいくらでもあるけど)
0531名無しさん@お腹いっぱい。2009/04/20(月) 14:16:51
仕事で使うのは最近はkshばかりだなー
マイナーという
0532名無しさん@お腹いっぱい。2009/04/20(月) 14:17:41
マイナーというのはどうかな
0533名無しさん@お腹いっぱい。2009/04/20(月) 14:35:10
>>527
なぜかOpenBSDで使われているShellって感じですね

2000年まで、Korn shell は AT&T の権利保有するソフトウェアであった。その後AT&T独自
のライセンスの下でオープンソースとなり、2005年から Common Public License での配布
となった。Korn shell は AT&T Software Technology (AST) Open Source Software
Collection の一部として入手可能である。
と書いてあるけど、2000年以前は無料で使えなかったんでしょうか?
10年前ぐらい訳本には商用うんぬんと書いていないから15年前ぐらいからは入手的には困らなかったんだろうか
OpenBSD誕生が1996年みたいだけど、標準Shellは、なんだったのだろうか
最初からksh?

あとなんちゃってUNIXユーザーとしては、知名度だと
bash >>> sh >= zsh >= tcsh >> csh > ksh ぐらい違う
それ以外のマイナーなShellは、自分の中に存在しません
>>529
bash誕生が1987年、Linux誕生が1991年なんですけど、簡単にbashは入手しづらかったんでしょうか?
>>531
Linuxだと標準では入っていないけど、kshは入れるものなんでしょうか?
ビジネスでの普及度はどんな感じなんですか?
対話シェルはbashとか、他のなにかでshスクリプトの実行はkshって感じなんでしょうか?
それともshに対応しないkshスクリプトを書くの?
>>532
今でもひそかなファンが多いし、重宝されていると言えばいいのかな
0534名無しさん@お腹いっぱい。2009/04/20(月) 14:40:33
>>533
>それともshに対応しないkshスクリプトを書くの?

普通書かない。
shに対応しないkshスクリプトの代表例と言えば [[ ]] の記述。

sh的には if [ "$hoge" = fuga ]; then と書くところを、
kshでは if [[ "$hoge" == fuga ]]; then と書く。

でも、こんなの滅多に見ないだろ。それほど kshはマイナー。
0535名無しさん@お腹いっぱい。2009/04/20(月) 15:02:26
>>533
Linuxには入れちゃうよーん
0536名無しさん@お腹いっぱい。2009/04/20(月) 15:27:09
客先とかだと勝手に入れられない。
0537名無しさん@お腹いっぱい。2009/04/20(月) 16:31:48
もちろん設計段階で盛り込むんだよーん
0538名無しさん@お腹いっぱい。2009/04/20(月) 16:35:48
自分が一生面倒見ますくらいじゃないとそんなの入れられない
特に自社システムじゃなく受託開発なら
トラブル時に責任問題にもなる
0539名無しさん@お腹いっぱい。2009/04/20(月) 16:39:40
なんか、どうでもいい話だな。
0540名無しさん@お腹いっぱい。2009/04/20(月) 16:41:47
サポートのあるものを入れれば大丈夫だよん
0541名無しさん@お腹いっぱい。2009/04/20(月) 16:43:27
>>540
具体的には?
0542名無しさん@お腹いっぱい。2009/04/20(月) 16:57:46
redhatとかsuseとか
それぞれのベンダが提供しているやつ
0543名無しさん@お腹いっぱい。2009/04/20(月) 17:08:15
OpenBSDのkshはpdkshじゃなかったっけ?
0544名無しさん@お腹いっぱい。2009/04/20(月) 17:21:19
たいていpbksh
0545名無しさん@お腹いっぱい。2009/04/20(月) 21:06:27
$ ksh
プログラム 'ksh' は以下のパッケージで見つかりました:
* ksh
* mksh
* zsh
* pdksh
次の操作を試してください: sudo apt-get install <選択したパッケージ>

やはりここはpdksh?
0546名無しさん@お腹いっぱい。2009/04/20(月) 21:46:52
OSが起動した日時を取得する、いい方法は無いでしょうか?
起動からの経過時間でなく、起動日時です。
出来ればシリアル値(1970からの経過秒)で取得できれば嬉しいです。

uptimeの結果から計算するのは起動からの経過時間によってフォーマットが
(daysやminが付いたり、付かなかったり)違うため出来れば避けたいです。
GNU、bash依存でもかまいません。
0547名無しさん@お腹いっぱい。2009/04/20(月) 21:52:23
cat /proc/uptime
0548名無しさん@お腹いっぱい。2009/04/20(月) 21:56:22
cat: /proc/uptime: No such file or directory
0549名無しさん@お腹いっぱい。2009/04/20(月) 21:58:37
だからBSD*は駄目なんだよ
0550名無しさん@お腹いっぱい。2009/04/20(月) 22:14:36
>>546
GNU 依存でいいなら、

date -r /

(ルートディレクトリのタイムスタンプは起動時に touchされて
その後書き込みは普通は発生しないことを利用)
0551名無しさん@お腹いっぱい。2009/04/20(月) 22:18:32
$ date -r /
2009年  2月  6日 金曜日 21:12:47 JST

ずれまくりワロタ
0552名無しさん@お腹いっぱい。2009/04/20(月) 22:24:36
>>545
好きにすればいいじゃない
0553名無しさん@お腹いっぱい。2009/04/20(月) 22:31:52
>>550
OpenBSD on VMware on WindowsXPでやったら、Thu Jan 1 09:00:00 JST 1970になった
まあ、OpenBSD on VMwareだからしゃないやな
05545532009/04/20(月) 22:46:48
ubuntu8.04 LTS on VMwareだとVM作成時の年数日時
Scientific on VMware,Fedora11 on VMwareだとちゃんと出るんだな

まあ、どうでもいい話でした
05555012009/04/21(火) 00:03:03
>>508の質問の件ですが、御陰様で無事に動きますた。

ただしおいらの環境だと、>>511さんのプログラムのままでは
 2009/04/19 01:23:45,user,ip=[192.168.1.2]
のような結果になってしまうので、whileのダミー引数を増やしました。

最終的にこんな感じにしますた。
(※全角スペースでインデントしています)

----
#!/usr/local/bin/ksh

YEAR=`date +'%Y'`
while IFS=' =,[]' read mon day time d1 d2 d3 d4 d5 d6 d7 d8 user d9 d10 ip d11
do
  case $mon in
    Jan)mon=01;; Feb)mon=02;; Mar)mon=03;; Apr)mon=04;;
    May)mon=05;; Jun)mon=06;; Jul)mon=07;; Aug)mon=08;;
    Sep)mon=09;; Oct)mon=10;; Nov)mon=11;; Dec)mon=12;;
  esac
  echo $YEAR/$mon/$day $time,$user,$ip
done
----
05565012009/04/21(火) 00:07:41
続きです。

スクリプトの実行速度なんですが、約10万行のログを処理したところ、
kshではなんと4秒で終わっちゃいました。

ちなみに/bin/shで動かしたら、27秒もかかっちゃいまして、
処理性能の違いに驚いた次第であります。
おまいら、ありがとうございますた。
0557名無しさん@お腹いっぱい。2009/04/21(火) 01:03:04
>>556
ちなみにOSは?
0558名無しさん@お腹いっぱい。2009/04/21(火) 01:13:39
>>555
報告おつ
比較をわかりやすく、30万行じゃないのねw

6.75倍はすごいね
05595012009/04/21(火) 01:26:31
>>557
処理時間を計ったのはVMware上で動いているFreeBSD7.1ですが、
Solaris9(SPARC)でも動くのは確認しますた。


>>558
手元にあったのが10万行のログだったので、
とりあえずこれで試しますた。
深い意味はありませんw
0560名無しさん@お腹いっぱい。2009/04/21(火) 01:31:08
>>546
こんなのどうかな。
GNU依存だし、動かないパターン多そうだけど。

$ last | grep '^reboot' | head -1 | awk '{print $5" "$6" "$7" "$8}' | date -f - '+%s'
0561名無しさん@お腹いっぱい。2009/04/21(火) 01:40:08
今月起動したっていう場合しか無理っぽいな
0562名無しさん@お腹いっぱい。2009/04/21(火) 01:50:16
>>561
wtmp って1月分しか残らないんだっけ?
そう言えば、/proc/uptime はサイズどれだけ有るんだっけ(溢れることはない?)?
0563名無しさん@お腹いっぱい。2009/04/21(火) 03:07:54
bashで、三項演算子を使いたいのですが、どのようにするのでしょうか?
0564名無しさん@お腹いっぱい。2009/04/21(火) 03:55:34
shellはダイナミックライブラリのとスタティックのが有るから、ベンチ遣るならダイナミックのほうが有利だろうな。
0565名無しさん@お腹いっぱい。2009/04/21(火) 07:16:33
>>563
たとえば、
echo $((x > 0 ? x: -x))
とか。
0566名無しさん@お腹いっぱい。2009/04/21(火) 07:38:41
俺の解釈では
A && (B; true) || C
かと。
0567名無しさん@お腹いっぱい。2009/04/21(火) 08:20:54
>>566
アフォか。
それは普通の「2項」の演算子の組み合わせ。
しかも、bash限定でもない。

>>565 が正解。
0568名無しさん@お腹いっぱい。2009/04/21(火) 09:59:52
正解は>>565
>>567は>566に輪をかけたアフォ。
「bashで」というお題は「bash以外では動作しない == bash限定」事を要求していない。
0569名無しさん@お腹いっぱい。2009/04/21(火) 10:53:47
頭のおかしい人はスルーで
はりきるだけだから
0570名無しさん@お腹いっぱい。2009/04/21(火) 11:12:24
するーされてるが >>564 もあふぉだな。
ここでのベンチ(kshとbash)は、ライブラリが動的か静的かよりもはるかに大きい
差を生じているので、そんな点を指摘しても無意味。
さらにアフォな点は、バイナリは「スタティックリンク」の方が速い(有利)ということ。
>>564 は全く逆に覚えてるようだね。
0571名無しさん@お腹いっぱい。2009/04/21(火) 12:34:23
なんでスタティックリンクの方が速いんだ?
0572名無しさん@お腹いっぱい。2009/04/21(火) 12:40:45
>>571
素で質問してるならぐぐれ。
釣りなら面白くない。
0573名無しさん@お腹いっぱい。2009/04/21(火) 13:33:19
ファイル名を通し番号に変えたいんですけど
以下のスクリプトでエラーが出ます。

num=1

for file in *.m4a; do

mv $file $num.m4r

num=`expr $num + 1`

done


エラーは
mv: target `1.m4r' is not a directory
というものです。

シェルというよりmvコマンドの使い方の問題なのかもしれませんが
自分には原因がわかりません
教えてください
0574名無しさん@お腹いっぱい。2009/04/21(火) 13:42:53
>>571
共有ライブラリは間接呼出しになる。
0575名無しさん@お腹いっぱい。2009/04/21(火) 13:44:59
>>573
スペース入りファイル名が分割されて、
mv hoge hage.m4a 123.m4r
みたいに実行されたのが原因。

シェル変数の展開時には原則すべてダブルクォートを付けること。

mv "$file" "$num.m4r"
0576名無しさん@お腹いっぱい。2009/04/21(火) 13:45:06
>>573
ファイル名に空白(やタブ等)が含まれているのだろう。

mv "$file" $num.m4r
0577名無しさん@お腹いっぱい。2009/04/21(火) 14:04:48
>>575
>>576
なるほど、そういうことだったんですか!
まさにその通りで、ファイル名にスペースが入っていました。
ありがとうございます!
0578名無しさん@お腹いっぱい。2009/04/21(火) 21:57:17
>>546
すごく適当ですが・・・・こんな感じで OS ごとに書くしかないかと。

case `uname -s` in
'Linux')
  grep btime /proc/stat | cut -d ' ' -f 2
  ;;
'FreeBSD')
  cut -d ' ' -f 8 /proc/1/status | cut -d ',' -f 1
  ;;
*)
  ;;
esac
0579名無しさん@お腹いっぱい。2009/04/22(水) 05:32:25
スタティクは全部読むから読み込みに時間がかかるし、ライブラリのキャッシュも効いてないぞ。
ダイナミックが遅いなら、みんなダイナミック使ってないwww
perlとかも普通はダイナミック。
0580名無しさん@お腹いっぱい。2009/04/22(水) 06:10:01
>>579
オマエ真性の勘違い野郎か。

スタティックリンクでも全部は読み込まない。
仮想記憶って知ってるか?
バイナリプログラムのうち、実際にCPUのプログラムカウンタが走った命令のアドレス
を含むメモリページのみが読み込まれる。実行されなかった部分は読み込まれない。

ダイナミックリンクのライブラリは、リロケーションの関係で、
PIC(ポジションインディペンデント)にコンパイルする必要があり、
PIC自体が通常のバイナリよりも数%遅い。

ライブラリのキャッシュについては確かにいうとおりだが、
これは他の要素に比べて影響は小さいので、
やはりダイナミックリンクの方が遅い。

ダイナミックリンクは遅いが、HDDの節約や、ライブラリのupdateの際に
リンクしてる個々のバイナリを再コンパイルしなくて良い便宜のために
使用されている。どうしても速度優先の場合は、
スタティックリンクを使うことがあるよ。
0581名無しさん@お腹いっぱい。2009/04/22(水) 06:36:28
>>580 に補足。
ライブラリは複数の関数の集まりでできているが、
スタティックリンクの場合、それらの関数のうち、使用している関数だけが
コンパイル(ld)時にリンクされる。使っていない関数はそもそもリンクされない。
(使っていても条件によって呼び出されなかった関数は
仮想記憶によってメモリにはロードされないままになる可能性があるのは
>>580 がいう通り)

ダイナミックリンクの場合は、使っていない関数まで
実行時に塊で付いてきてしまう。
0582名無しさん@お腹いっぱい。2009/04/22(水) 06:57:20
ダイナミックリンク/スタティックリンクの速度の違いなんて小さいからどうでもいい。
それよりもバイトコンパイルやらコマンド組み込みやらの方が効果でかいはず。
0583名無しさん@お腹いっぱい。2009/04/22(水) 07:57:48
>>579
間違った知識ばらまいてないで、実験してみればいいのに。

$ cat hoge.c
#include <stdio.h>
int main(){printf("Hello¥n");return 0;}

$ gcc -o dynamic hoge.c
$ gcc -o static hoge.c -static

$ time ./dynamic
Hello

real 0m0.004s
user 0m0.000s
sys 0m0.001s

$ time ./static
Hello

real 0m0.002s
user 0m0.000s
sys 0m0.000s


スタティックリンクの方が速いね。
0584名無しさん@お腹いっぱい。2009/04/22(水) 09:15:01
>>563
ミリ秒オーダでしか違わないんじゃほとんどの場合は
そんなこと気にするよりまともなプログラム書いたほうが
いいなw
0585名無しさん@お腹いっぱい。2009/04/22(水) 09:37:11
>>584
dynamicもstaticも「ほとんど違わない」ので、それ以外の要素による違いの方が大きい
ということは元々 >>570 が指摘してる。(こっちが要点)

それ以外に、>>564 は「ダイナミックの方が速い」と間違ってることを言ってるるので、
それをついでに指摘しただけ。

で、>>579 で未だに「ダイナミックの方が速い」の主張を続けるから、
>>580 がそれを否定しているだけ。

別に>>580 が、シェルスクリプトのシェルをスタティックにしろと主張している
わけではない。

元の質問に戻って、>>508 の場合、外部コマンドの cutの呼び出しが多数ループ
されるので、それが遅かったのが原因と思われる。
>>511 はシェルの内部コマンドだけを使っているので、それで激劇に速くなったと。

いすれにしても、その話の流れを読まずに
>>564 で見当違いかつ間違った指摘をしている >>564 はアフォ。
0586名無しさん@お腹いっぱい。2009/04/22(水) 10:22:55
>>580
> ライブラリのキャッシュについては確かにいうとおりだが、
> これは他の要素に比べて影響は小さいので、
> やはりダイナミックリンクの方が遅い。

嘘八百のおバカさん
0587名無しさん@お腹いっぱい。2009/04/22(水) 10:31:05
>>585
主張する内容自体に問題くても、必死すぎるとキモいものだな...
まあ落ち着け。
0588名無しさん@お腹いっぱい。2009/04/22(水) 10:35:53
通常の実行バイナリがstaticかdynamicかという問題のほかに、
>>579 は perlの「ダイナミックロード」のライブラリ(モジュール)の話と
混同してるフシがあるな。(わざわざ的外れなperlを例に持ち出してきてるあたり)

>>579 にとって、「ダイナミック」とは、perlでしかイメージできてなくて、
普通にCをコンパイルする時のstatic linkとdynamic linkを違いを
全く理解できてない(存在自体知らない?)んだろう(笑)
0589名無しさん@お腹いっぱい。2009/04/22(水) 10:49:32
>>584
問題です。
Ubuntuでは、dashをビルドする際に、libcを使わずdietlibcに変更した上で、
スタティックリンクしています。これはなぜでしょうか。
ヒント:Ubuntuでは/bin/shとしてdashを使っています。
0590名無しさん@お腹いっぱい。2009/04/22(水) 11:07:22
ld.so関係で事故が起きても動くように。
スタティックリンクの方が速いからではない。
そもそも速くないし。
0591名無しさん@お腹いっぱい。2009/04/22(水) 11:11:36
>>590
>そもそも速くないし。

は間違い。実際速い。

それ以外にstatic linkにする利点と、さらにdietlibcに変更する理由を質問してる。
>>590 では答えになっていない。

ハイ、答え直し >>590 >>584
0592名無しさん@お腹いっぱい。2009/04/22(水) 11:12:45
それっぽく書くだけで人はこんなにもだまされるんだな。
ちゃんと自分の頭を使って自分の体を動かして自分の目で確認しろよ。
0593名無しさん@お腹いっぱい。2009/04/22(水) 11:31:22
linux はスタティックリンクなバイナリのように見えても、
NSS まわりとかで必要があれば勝手にダイナミックでリンクしちゃうから
わりとどーでもいい。
0594名無しさん@お腹いっぱい。2009/04/22(水) 11:47:34
>>593
争点をぼかすことになるから、ここでは dlopen()系の話は持ち込まない方が
話が簡単になるかと。どうせあほは >>579 1人だろうし。
0595名無しさん@お腹いっぱい。2009/04/22(水) 12:33:36
staticリンクするとGPL汚染するからGPL信者には都合がいい。
しかもdietlibcはLGPLでなくGPLなのでダイナミックリンクでも汚染する。
0596名無しさん@お腹いっぱい。2009/04/22(水) 12:35:04
>>579
すさまじい勘違いだなw
0597名無しさん@お腹いっぱい。2009/04/22(水) 12:38:47
>>584
このオーダーも特に速度が必要な場合は馬鹿に出来ないよ。
まぁ、dynamicかstaticかの違いより、根本的な設計の方がよっぽど大きいけど。
0598名無しさん@お腹いっぱい。2009/04/22(水) 12:49:51
>>597
ミリ秒オーダーの起動オーバヘッドが問題になるほど実行時間の
短いプログラムを何度も起動するのはそもそも設計が悪いよね
0599名無しさん@お腹いっぱい。2009/04/22(水) 12:59:45
>>598
オーバヘッドは「プログラム起動時」だけじゃないよ。
dynamicなライブラリ上の関数を呼び出すたびにオーバーヘッドがかかる。
さらに、関数自体がPICによって速度上不利なコードで書かれているから遅くなる。

staticライブラリなら、プログラム中に絶対アドレスを決めうちで持つから、
その分のオーバーヘッドがなく高速動作する。
0600名無しさん@お腹いっぱい。2009/04/22(水) 13:10:18
ダイナミックリンクが遅い派の人って、なんか宗教じみてるよね
結論ありきというか
そうでないと世界が崩壊しちゃうんだろうね
0601名無しさん@お腹いっぱい。2009/04/22(水) 13:18:31
>>600
今まで「ダイナミックリンクの方が速い」と間違って覚えていて
散々恥を晒した気分はどうだい? >>600 = >>579
0602名無しさん@お腹いっぱい。2009/04/22(水) 13:22:13
>>600
自己紹介乙。
そうか、今までdynamicの方が速いと信じこんでいて、それが間違いだと知って
キミの世界が崩壊しちゃったのか、、よしよし
0603名無しさん@お腹いっぱい。2009/04/22(水) 13:50:41
これ、シェルスクリプトの話?
0604名無しさん@お腹いっぱい。2009/04/22(水) 17:24:32
いんにゃ、全てのライブラリをスタティックリンクさせてメモリを圧迫させようとする秘密組織の陰謀。
0605名無しさん@お腹いっぱい。2009/04/22(水) 23:37:03
すべてのプログラムをGPLに汚染するGNU組織の陰謀だろwww
0606名無しさん@お腹いっぱい。2009/04/22(水) 23:52:09
>>605
ま、次から間違えないようにすれば良いじゃないか。

0607名無しさん@お腹いっぱい。2009/04/23(木) 22:37:10
echo aaabbbccceee | sed 's/aaa//' | sed 's/ccc//'
という場合のsedをひとつにできますか?
0608名無しさん@お腹いっぱい。2009/04/23(木) 22:43:22
>>607
echo aaabbbccceee | sed 's/aaa//;s/ccc//'
0609名無しさん@お腹いっぱい。2009/04/23(木) 22:55:44
>>607

$ alias ひとつ=sed
$ echo aaabbbccceee | ひとつ 's/aaa//' | ひとつ 's/ccc//'
0610名無しさん@お腹いっぱい。2009/04/23(木) 23:29:40
echo aaabbbccceee | sed -e 's/aaa//' -e 's/ccc//'
0611名無しさん@お腹いっぱい。2009/04/24(金) 00:10:17
sed | sed って書く香具師ホント多いよな。1つの sed で何個も書けるのにw
個人的には、見やすさも考えてこんな風に書くこと多いかな。

sed -e 's/afo/moe/g' \
   -e 's/unko/umai/g' \
   -e 's/ahya/uhyo/g'

あと、文字列に / がいっぱい入るときは \/ じゃなくって、そもそも / を使わない。

s|/afo/desu/yo|/unko/tabe/tai/ne|
0612名無しさん@お腹いっぱい。2009/04/24(金) 00:41:35
蛇の足まで描くな
0613名無しさん@お腹いっぱい。2009/04/24(金) 06:46:28
あと、sedとgrepを | でつなぐ奴とか。もうあほかと。
0614名無しさん@お腹いっぱい。2009/04/24(金) 09:27:04
でも少しずつ様子を見ながら作業してるときは、お尻に付け足すほうが
カーソル戻さなくていい分楽なのでついやっちゃうんだよな...
0615名無しさん@お腹いっぱい。2009/04/24(金) 11:10:54
>611
実行速度が大きく違う時がある
-e よりは sed | sed | sedの方が速いときもある

ケースバイケースでしょ
0616名無しさん@お腹いっぱい。2009/04/24(金) 11:47:58
>>613
インターネットで俺の悪口を言うのは止めてくれないか ><
0617名無しさん@お腹いっぱい。2009/04/24(金) 12:46:50
オレのことではないと分かってほっと一息
0618名無しさん@お腹いっぱい。2009/04/24(金) 19:58:34
sedの件ありがとうございます
ただひとつの場合-eはなくてもいいのに複数の場合は必須なんですね?
0619名無しさん@お腹いっぱい。2009/04/24(金) 20:08:32
>>618
>>608 の形式なら -e は不要。
0620名無しさん@お腹いっぱい。2009/04/24(金) 23:03:44
まあコマンドで出力しぼったりしてるときは grep | sed とか書いてもいいべ
0621名無しさん@お腹いっぱい。2009/04/25(土) 04:52:34
sedが3つも起動されてるのはどうだか。
0622名無しさん@お腹いっぱい。2009/04/25(土) 09:27:36
いまどきのマシンなら3つぐらい余裕で動く
0623名無しさん@お腹いっぱい。2009/04/25(土) 09:49:23
>>615
sed 's/afo/moe/g;s/unko/umai/g;s/ahya/uhyo/g'
よりも、
sed | sed | sed の方が速いことはあり得ない。

×ケースバイケース
>>615 の負け惜しみ
0624名無しさん@お腹いっぱい。2009/04/25(土) 10:29:36
615は -e って言ってるのに
■ このスレッドは過去ログ倉庫に格納されています