sed
>16 ありがとうございます 後は加工して使おうと思います。 ど素人です。 sedでMIFESのグローバル置換みたいなことってできないですか? あるディレクトリに存在する複数のファイルをワイルドカード指定で入力して 一括して置換してもとのファイルにリダイレクトしてやるみたいな。 下記のイメージで(下記はとおらないですけど・・)。 sed -e 's/aaa/zzz/g' < * > * 1日中ぐぐってぐぐってもがいたけどわかりませんでした。すごいひと教えてください。 すごくなくてもできる。とりあえず、シェルスクリプトすれに池。 もっと短くできるが、何をやっているかわかりやすく説明するのをかねて↓ find -type f | while read file ; do mv ${file} ${file}.backup cat ${file}.backup | sed -e "s/aaa/zzz/g" > ${file} done 次世代sed登場 ttp://news.tbs.co.jp/newseye/tbs_newseye1037945.html >>19 おわっ。あっさりできたっ。どうもありがとです! シェルスクリプトすごい便利。勉強しなきゃですね・・。 bash上でなのですが、 hoge=`echo ../tmp/work.c | sed 's/\//\\\//g'` を実行しようとすると、 sed: -e expression #1, char 9: Unknown option to 's' となってしまうのは、なぜですか? /を\/に置換したいだけなのです。 うーん、確かにシェル向けのネタなのかもですが、 echo ../tmp/work.c | sed 's/\//\\\//g' だけだと動くのがよくわからなくって。 いいことを教えてあげよう。 's@hoge@hage@g'とやってごらん。 command not found でした・・・って、そういう意味ではないのかな・・・。 s/..../..../g は s@....@....@g とも書ける という意味 Filesystem Size Used Avail Use% Mounted on /dev/hda5 9.6G 844M 8.3G 10% / というのを ~$ df /home/ | sed -n -e "2s/.*\(\d*\)%.*/<\1>/p" として10を取り出したいのですがうまくいきません 結果は <> となります どうすればいいのでしょうか? space, tab を区切りにして何番目の要素って選択したほうがいいんじゃないの。 先頭の.* が % の直前までマッチし、 \d* が長さ0、 % が % にマッチ、 最後の .* が残りの部分にマッチしてるからね。 しーずか〜な〜しーずかな〜 さーとのーあ〜きぃ〜 おーsed〜にきぃ〜のみが〜 お〜ちる〜よ〜は〜 temp.txt中の"-"と"+"以外の文字を空白に変換するには sed 's/[^\-\+]/ /g' temp.txt でうまくいきますが、temp.txt中の"-"と"+"と数字以外の文字を空白に変換するには どう記述すればよいのでしょうか sed 's/[^\-\+0-9]/ /g' temp.txt では文法エラーになってしまいます。 >>38 +と−の順番が逆でした。 以下に訂正。 temp.txt中の"-"と"+"以外の文字を空白に変換するには sed 's/[^\+\-]/ /g' temp.txt でうまくいきますが、temp.txt中の"-"と"+"と数字以外の文字を空白に変換するには どう記述すればよいのでしょうか sed 's/[^\+\-0-9]/ /g' temp.txt では文法エラーになってしまいます。 うちの OS だと、ならんけど? まあ sed 's/[^-+0-9]/ /g' temp.txt って書いた方が簡潔だとは思うが。 >>40 > うちの OS だと、ならんけど? > まあ > sed 's/[^-+0-9]/ /g' temp.txt > って書いた方が簡潔だとは思うが。 Cygwin についてくるsed です。 sed 's/[^-+0-9]/ /g' temp.txt これは問題なく正常動作しました。 >>41 > > >>40 > > うちの OS だと、ならんけど? > > まあ > > sed 's/[^-+0-9]/ /g' temp.txt > > って書いた方が簡潔だとは思うが。 > > > Cygwin についてくるsed です。 > > sed 's/[^-+0-9]/ /g' temp.txt > > これは問題なく正常動作しました。 > > sed 's/[^+-0-9]/ /g' temp.txt にするとだめです。 +と0の間にあるコードと解釈されるらしい。 FreeBSD の sed って c コマンドの後のコマンドも実行するね。 これってバグじゃね? perlは、難しいので sed & awkでやって逝く事にしました。 若者は、PERLを消化して部位部位いわせsed&AWK何それ?状態 案外、sed&AWKを学ぶ必要がなかったりする? 新しいのについて行けずに、たちどまってしまったオッサンは、sed&AWK せめてPERLぐらいやる。だだでえくいっぱぐれてるのに 両方の言語を使用したことのあるエキスパートに意見を伺いたい sed&AWKなら簡単にできてPERLなら難しい処理例 PERLなら簡単にできてsed&AWKなら難しい処理例 若者、おっさんに向けての指針等など sed 's/hoge/hage/' のほうが perl -pe 's/hoge/hage/' より短い。 大岡山のキティに英語の勉強しろといわれたので、伊藤和夫先生のテキストで勉強しました -xx-xx-xxなperlは、使用しない故スティーブンス先生にも意見を聞きたいので >>59 召還ヨロシク sed 's/い/お/g' file で、 file内の「いっぱい」が「おっぱい」に置換されるのは、 正 常 ! s/い/お/g ←「g」付きだと置換結果は「おっぱお」じゃないの? 質問です。bashにてGnu sed ver4.0.9を用いて echo hoge,uge,hage,age,sage | sed 's/uge,.*\?,//g' を実行しました。 hoge,age,sage が出力されることを期待したのですが、実際の出力は hoge,sage でした。 *や+の後に?を指定すると、例えばperl,pythonなんかでは *や+は non greedy となるので、 sedでもそうなるものと考えてたのですが、何か間違っていたのでしょうか。 また、*や+を non greedy とするにはどうすれば良いのでしょうか。 よろしくお願いします。 >>62 man sed しました? man sed の SEE ALSO 見ると、 GNU sed が regex(7) (POSIX 1003.2) に (大体) 準拠してるとあると思いますが、 POSIX 1003.2 に non greedy な量指定子は無いです。 何か他の方法をとる必要があるかと。 ありがとうございます、とりあえず>62に関しては 's/uge,[^,]*,//' とすることにします。 >>58 > 大岡山のキティに英語の勉強しろといわれたので、伊藤和夫先生のテキストで勉強しました だれ? >>65 echo abc xyz |sed -e "s/^/%/; :ll; s/[%]\(.\)\(.*\) \(.\)\(.*\)/\1\3%\2 \4/; tll; s/%//;" >>66 >だれ? は、 >大岡山のキティ >伊藤和夫 の以上2つのうち誰の素性を知りたいのだね? 68は「大岡山のキティ」本人で複数の人間に「英語の勉強しろ」と言っていた、 という可能性は無いの。 >>70 「大岡山のキティ」に心当たりがあるなら>>66 のためにも、sedのsコマンドで「大岡山のキティ」を痴漢するってのは如何 GNU sedのVersion 4で、マルチバイトパッチをあてたVsersion 3みたく文字コー ドを決めうちして変換する(ctype=EUCみたいに)方法はないのでしょうか。 jiskan16.bdfに外字を足してテキスト処理をやっているのですが、行頭に外字の コードがくると、Version 4.1.4では誤認識してしまうのをなんとかしたいのです が。 FreeBSDでutf-8なロケールでgrep使えばOK。 sedで四則演算系は作れますか? 理由も教えてください。 >>72 bashを使っているとして、LANG=ja_jp.eucJP sed -e "s/hogehoge/fugaguga/" みたいなのじゃダメなの? >>77 情報小出しですみません。LNAGは設定してます。 ググってもsedの古いソースがみつからなかったので、とりあえずは、Vine2.6 の3.0.2 (だかなんだかの)のバイナリを入れて動かしてますんで、当面は困っ てはいないのですが、システムのバージョン上げるときに、個別対応する項目 が増えるのは面倒だなと思って質問した次第です。 >>81 GNU sedは4.xでマルチバイト文字対応が別の形で入ってるからね。 3.Xのローカライズパッチではそれほど厳密には検査されなかった 文字範囲が厳しくなってる可能性がある。 内部的には wide character に変換してごにょごにょしてるんだけど、 外字だとここでひっかかるのかもね。最悪自分でソースに手を入れて wrapper関数書くしかないかも(外字をPUAにわりあてちゃうとか)。 >>81 > ググってもsedの古いソースがみつからなかったので、 Ring server にあらかたのバージョンあったよ。 もちろん日本語対応パッチはそこにはないんだけど (これはほかを探せばある)。 >>84 ,85 Nに加えて、sなどで意図的にパターンスペースに改行を入れることもあるよ。 Nを行の先読みに例えれば、後者は行の差込み挿入のような意図で行うんだけど。 その場合にもdとDの違いが出る。 半角かなをsedで一括置換しようと 下のようなスクリプトを試しましたが うまくいきません 解決策を教えてください s/タ/\\={a}/g s/ツ/\\={\\i}/g s/ト/\\={u}/g s/ニ/\\uc{r}/g s/ヌ/\\uc{\\={r}}/g s/ハ/\\uc{l}/g s/゙/\\d{h}/g s/ワ/\\d{m}/g s/フ/\\.{n}/g s/ホ/\\~n/g OSはwindowsXPですが sedはunix由来だからここで伺ってます すみません >>87 UNIX上のsedなら、それでちゃんと動作するよ。 >>88 すみません、nkfで上記の置換を行う方法がわかりません よければ教えてください >>89 可能であれば、windowsで動作した方がいろいろと好都合 ですので... >>90 UNIX上のsedでは動作 ↓ sedの文法はそれで間違ってない ↓ Win版のsedのバグまたは仕様 ↓ UNIX板でこれ以上聞いても無駄 88、89さん申し訳ありません wiodows上でのsedでも87のsed置換は可能です 私の勘違いでした 改めて質問させていただきます 設定済みmeadowを使って リージョンを設定して M+shift+|で87のsedスクリプトを走らせた場合 \になってほしい部分が化けてしまいます 原因や対処方法がおわかりに方がいらっしゃったら ご教示願えませんでしょうか? set-process-coding-system >>93 ヒントありがとうございます 上述したように リージョンにコマンドを渡す方法を使う場合 set-process-coding-systemの記述は どこに、こんな風に記述すればよろしいのでしょうか? 頭が悪いので設定方法がわかりません よろしければ教えてください >>94 ずっと効くから.emacs に書いとけ。 >>92 半角かなばっかりの文書を置換するのはできるみたいですが 漢字が混じってたら漢字は化けます 対処方法がありますか? >>96 > 対処方法がありますか? おまえ朝鮮人のにおいがぷんぷんするんだが。 やっぱり朝鮮人だったか。おねがいだから、国に帰ってくれ。 sed /^$/q が「最初の空行までを出力する」ということで、メールのファイルからヘッダ部分を 抜き出すのに使えることがわかったのですが、その逆「最初の空行から後を出力 する」のはどうするのがよいでしょうか? 「sed ではなく○○を使え」とかいうことになるのかもしれませんが…… >99 なるほど。「最初から空行までを削除する」と読むわけですか。 98の「空行が見つかったら終了する」も奥が深いと思ったのですが、まだまだ精進が 足りませんね。ありがとうございました。 $ cat hoge.txt A\textrm{1}\textrm{23}\textit{456}B A\textrm{1}\textit{23}\textrm{456}B のようなファイルがあるとして \textrm{}を取り除いて A123\textit{456}B A1\textit{23}456B を取り出したいと思い $ < hoge.txt sed 's/\\textrm{\(.*\)}/\1/g' と書きましたが,括弧の対応を外側から取るようで A1}\textrm{23}\textit{456B A1}\textit{23}\textrm{456B と出力されてしまいます. うまい方法はありませんか? {\(.*\)}の部分が最長マッチしちゃんだから、ここのマッチが}で切れるよう {\([^}]*\)}に変えればいい。 >>104 なるほど! どうもありがとうございます. コマンドラインオプションの -n がよく理解できないんですが、どういう場面で使えばいいんでしょうか >>111 否定疑問文だから、英語で答えるなら "No" が正解だろ。 >>111-113 Thank you all. 知恵と勇気と愛でなんとかしてみる 否定疑問文に 「んなことない」みたいな答え方はどうしたらいい? read.cgi ver 07.5.4 2024/05/19 Walang Kapalit ★ | Donguri System Team 5ちゃんねる