シェルスクリプトに関する総合スレッドです。
全般
・荒しは無視しましょう。
・丁寧な姿勢を心掛けましょう。
・ネチケット(死語)を意識しましょう。
前スレ: シェルスクリプト総合 その27(https://mevius.5ch.net/test/read.cgi/unix/1525337663/)
探検
シェルスクリプト総合 その28
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん
2018/07/24(火) 11:01:16.36ID:r0TJj2hB2018/08/03(金) 22:52:05.62ID:8YejLfKY
はぁ、シェル「スクリプト」かどうかの問題じゃないんだってば
>>93はevent not foundってでなかったんで
考えるのメンドーなんでぐぐって
https://qiita.com/Qutjl/items/6e0056853c94011d245b のネタパクるけどさ
$ ruby -e "puts 'Hello, World!'"
-bash: !': event not found
はい、たしかにそうなりますね。
テキストエディタで「puts 'Hello, World!'」という内容のcode.txtファイルを作成する
$ cat code.txt
puts 'Hello, World!'
$ a=$(cat code.txt)
$ echo "$a"
puts 'Hello, World!'
変数 a に先程の文字列を入れました
$ ruby -e "$a"
Hello, World!
はい、エラーになりません。
これはシェルスクリプトが特殊なんじゃねーよ。
C言語で、ソースコードに"\n"と書いてある文字列をprintfした時と
\nという文字列が入っている変数をprintfした時の挙動と一緒だろうが
プログラミングの基礎やで。ソースコードをパースするときの処理かどうかの違い
>>93はevent not foundってでなかったんで
考えるのメンドーなんでぐぐって
https://qiita.com/Qutjl/items/6e0056853c94011d245b のネタパクるけどさ
$ ruby -e "puts 'Hello, World!'"
-bash: !': event not found
はい、たしかにそうなりますね。
テキストエディタで「puts 'Hello, World!'」という内容のcode.txtファイルを作成する
$ cat code.txt
puts 'Hello, World!'
$ a=$(cat code.txt)
$ echo "$a"
puts 'Hello, World!'
変数 a に先程の文字列を入れました
$ ruby -e "$a"
Hello, World!
はい、エラーになりません。
これはシェルスクリプトが特殊なんじゃねーよ。
C言語で、ソースコードに"\n"と書いてある文字列をprintfした時と
\nという文字列が入っている変数をprintfした時の挙動と一緒だろうが
プログラミングの基礎やで。ソースコードをパースするときの処理かどうかの違い
2018/08/03(金) 23:09:12.00ID:5qGFGeHO
2018/08/03(金) 23:09:28.23ID:TC+4ZTQW
えぇ……
もしかして俺が間違ってるのかと不安になるほど自信満々な書き方だなw
もしかして俺が間違ってるのかと不安になるほど自信満々な書き方だなw
2018/08/03(金) 23:11:06.77ID:5qGFGeHO
2018/08/03(金) 23:14:28.27ID:5qGFGeHO
>>97
まあ...気にすんな。「ナニ」か違う(?)と思ったのだろう。よくわからんけど
まあ...気にすんな。「ナニ」か違う(?)と思ったのだろう。よくわからんけど
100デフォルトの名無しさん
2018/08/03(金) 23:28:02.17ID:h174pTLw 若者はヒストリー置換を知らないんだなあと感じいる俺はオッサン。
ヒストリー置換は対話的な入力にしか影響しないから、
スクリプトにするときは気にしなくていいよ。
ヒストリー置換は対話的な入力にしか影響しないから、
スクリプトにするときは気にしなくていいよ。
101デフォルトの名無しさん
2018/08/04(土) 02:05:18.25ID:j+kw9Zam102デフォルトの名無しさん
2018/08/04(土) 03:08:34.02ID:ddNokTrS イミフ
103デフォルトの名無しさん
2018/08/04(土) 03:15:50.13ID:ddNokTrS 初見イミフ、よく読んでもやっぱりイミフw
なんか問題点を勘違いしているでしょ
>>94のcaseからesacをコピペってみて実行してみ。たぶんそういう文脈での「シェルスクリプトになってるときは〜」だと思うぞ=間違ってはないと思うぞ
何を問題にしてんの?「インタラクティブシェル上でも変数を""で囲えば同じなのに」って
なんか問題点を勘違いしているでしょ
>>94のcaseからesacをコピペってみて実行してみ。たぶんそういう文脈での「シェルスクリプトになってるときは〜」だと思うぞ=間違ってはないと思うぞ
何を問題にしてんの?「インタラクティブシェル上でも変数を""で囲えば同じなのに」って
104デフォルトの名無しさん
2018/08/04(土) 03:24:02.15ID:XmDLxyoB なんでこんなに丁寧に教えてやらんと理解できんのか
>>62の話だろ
> だから、ディレクトリパス・ユーザー名とか、
> システムで使うものに、半角空白を入れたら、ダメ
>
> シェルスクリプトを書いている奴が、変数を" " で囲んでいないと、バグるから
ヒストリー展開はスクリプトだと既定で無効だが、
それ以前にファイル名にスペース入ってたりするから、
変数はダブルクォートでくくるのは当たり前なんだよ。
shellcheckすればデフォルトで指摘される項目
変数はダブルクォートでくくればいいって言ってんのに
今度は「ファイル名にダブルクォートが入っていたら?」
「ビックリマークが入っていたら?」とか言い出してんだろ
そ・れ・も「変数をダブルクォートでくくればいい」で終わりつってんだろ
ダブルクォートでくくればヒストリー展開が有効であっても
ファイル名に!が含まれてようが関係ない
>>62の話だろ
> だから、ディレクトリパス・ユーザー名とか、
> システムで使うものに、半角空白を入れたら、ダメ
>
> シェルスクリプトを書いている奴が、変数を" " で囲んでいないと、バグるから
ヒストリー展開はスクリプトだと既定で無効だが、
それ以前にファイル名にスペース入ってたりするから、
変数はダブルクォートでくくるのは当たり前なんだよ。
shellcheckすればデフォルトで指摘される項目
変数はダブルクォートでくくればいいって言ってんのに
今度は「ファイル名にダブルクォートが入っていたら?」
「ビックリマークが入っていたら?」とか言い出してんだろ
そ・れ・も「変数をダブルクォートでくくればいい」で終わりつってんだろ
ダブルクォートでくくればヒストリー展開が有効であっても
ファイル名に!が含まれてようが関係ない
105デフォルトの名無しさん
2018/08/04(土) 03:25:51.10ID:XmDLxyoB106デフォルトの名無しさん
2018/08/04(土) 03:26:21.86ID:ddNokTrS 違うよ。>>80の話だけだぞ?
107デフォルトの名無しさん
2018/08/04(土) 03:28:41.06ID:ddNokTrS ! と " は別の問題
話の流れをよめ...ってw だめだこりゃ
話の流れをよめ...ってw だめだこりゃ
108デフォルトの名無しさん
2018/08/04(土) 03:57:51.51ID:ZE1/UEds109デフォルトの名無しさん
2018/08/04(土) 04:07:16.79ID:ddNokTrS110デフォルトの名無しさん
2018/08/04(土) 07:02:26.79ID:fp3S0oAr ヒストリ置換知らないのはゆとり
111デフォルトの名無しさん
2018/08/04(土) 08:42:45.49ID:Zm4mz9Pa 俺はゆとり世代より下だがずっと指摘してたぞ(>>81)
そういう決め付けやめろ
そういう決め付けやめろ
112デフォルトの名無しさん
2018/08/04(土) 15:19:02.62ID:EGr8asH9 やはりIPも入れたほうがいいかね
113デフォルトの名無しさん
2018/08/04(土) 15:19:27.32ID:EGr8asH9 IPじゃねーやワッチョイ
114デフォルトの名無しさん
2018/08/06(月) 08:36:00.23ID:/d0+B2Ty ファイルやディレクトリを引数に取り、その許可属性を返すコマンドってありますか。
少なくともPOSIX Utilityにはないと分かっています。
期待する動作はそのコマンドの名前をownとして
$ own /some/file
-rwxrwxr-x
というような具合です。
少なくともPOSIX Utilityにはないと分かっています。
期待する動作はそのコマンドの名前をownとして
$ own /some/file
-rwxrwxr-x
というような具合です。
115デフォルトの名無しさん
2018/08/06(月) 09:07:09.56ID:BzDkzOUM lsすりゃ済むのにunix的なセンスでそんなコマンドは作らないよ
116デフォルトの名無しさん
2018/08/06(月) 09:23:02.61ID:Q3wSzLhg ls
それで満足できないなら作れ、さすがにそれくらいできるだろ
それで満足できないなら作れ、さすがにそれくらいできるだろ
117デフォルトの名無しさん
2018/08/06(月) 09:25:30.08ID:RuHjlTsU >>114
stat -c '%A' /some/file
stat -c '%A' /some/file
118デフォルトの名無しさん
2018/08/06(月) 09:26:53.13ID:4JbBAPy3119デフォルトの名無しさん
2018/08/06(月) 09:29:30.92ID:4JbBAPy3 うはっw NGワードで引っ掛かってあれこれ変えてる内に回答が二つ書かれてたw
120デフォルトの名無しさん
2018/08/06(月) 09:43:00.91ID:9v8Yooys >>117でわかるのに、unix的なセンスとか、ワロえる。
センスないのはむしろ。ぷぷぷw
センスないのはむしろ。ぷぷぷw
121デフォルトの名無しさん
2018/08/06(月) 10:15:49.41ID:BzDkzOUM なんか嘲笑してるつもり?
122デフォルトの名無しさん
2018/08/06(月) 11:45:03.11ID:jTWGCXc0123デフォルトの名無しさん
2018/08/06(月) 15:01:42.52ID:/d0+B2Ty stat -c '%A'
↑すばらしいです。ありがとうございました。
↑すばらしいです。ありがとうございました。
124デフォルトの名無しさん
2018/08/06(月) 20:56:55.63ID:Z/jXU7Rj125デフォルトの名無しさん
2018/08/10(金) 03:53:11.11ID:5eVCbRBd OpenWrtでこんなの見つけた。何処がオリジナルだろう?
物自体はバイナリだけどシェルスクリプトと親和性が高い(?)
JSONのパースと生成の方法のアイデアとして
https://wiki.openwrt.org/doc/devel/packages/jshn
Library for parsing and generating JSON from shell scripts
こんなふうに出力される
$ jshn -r '{"a":1, "b":2, "c": [1,2,3], "d": {"A":1}}'
json_init;
json_add_int 'a' 1;
json_add_int 'b' 2;
json_add_array 'c';
json_add_int '0' 1;
json_add_int '1' 2;
json_add_int '2' 3;
json_close_array;
json_add_object 'd';
json_add_int 'A' 1;
json_close_object;
物自体はバイナリだけどシェルスクリプトと親和性が高い(?)
JSONのパースと生成の方法のアイデアとして
https://wiki.openwrt.org/doc/devel/packages/jshn
Library for parsing and generating JSON from shell scripts
こんなふうに出力される
$ jshn -r '{"a":1, "b":2, "c": [1,2,3], "d": {"A":1}}'
json_init;
json_add_int 'a' 1;
json_add_int 'b' 2;
json_add_array 'c';
json_add_int '0' 1;
json_add_int '1' 2;
json_add_int '2' 3;
json_close_array;
json_add_object 'd';
json_add_int 'A' 1;
json_close_object;
126デフォルトの名無しさん
2018/08/10(金) 08:46:11.76ID:bLDrGgRY >>125
jq(1)が定番では?
jq(1)が定番では?
127デフォルトの名無しさん
2018/08/10(金) 11:19:27.53ID:zsXdw2zN128デフォルトの名無しさん
2018/08/10(金) 11:44:23.91ID:r84RRSaO129デフォルトの名無しさん
2018/08/10(金) 12:48:42.64ID:vqUG5YbC おかしな人の言い分だな、確かにw
130デフォルトの名無しさん
2018/08/10(金) 12:52:37.04ID:EBuB6o8O パイプで繋いで使えるようにってことかな
131デフォルトの名無しさん
2018/08/10(金) 13:42:12.09ID:ndPpyRQZ おかしな人がケチつけてたのって何年も前じゃん
132デフォルトの名無しさん
2018/08/10(金) 14:53:48.86ID:19uTC1v8 ああ、某原理主義者のことか
133デフォルトの名無しさん
2018/08/10(金) 14:57:29.03ID:xNR7R3k1 ポジックス
134デフォルトの名無しさん
2018/08/10(金) 15:54:52.38ID:ndPpyRQZ でもあの人の言うことなんて聞いてらんないよね。こっちは宗教で食ってるわけじゃないんだからさ。
作って見せたツールだって痒いところに手が届かない部分は
「そんなのはそもそもこうこうであるべきで必要ない」みたいな感じでほっぽってるし
作ってマウント取って射精後スッキリになったら全くメンテなんてしないし。「各人個別で改修・メンテしろ」ってことなんだろうけど、
こんなの個人の便利ツール止まりで世界中の不特定多数の共有便利ツール・知識にはなり得ないよ。
作って見せたツールだって痒いところに手が届かない部分は
「そんなのはそもそもこうこうであるべきで必要ない」みたいな感じでほっぽってるし
作ってマウント取って射精後スッキリになったら全くメンテなんてしないし。「各人個別で改修・メンテしろ」ってことなんだろうけど、
こんなの個人の便利ツール止まりで世界中の不特定多数の共有便利ツール・知識にはなり得ないよ。
135デフォルトの名無しさん
2018/08/10(金) 15:59:32.13ID:xNR7R3k1 何やってる人か知らんが、それはそれでいんじゃないの?
頼まれずに作ったツールの公開なんてオナニーそのものやろ
頼まれずに作ったツールの公開なんてオナニーそのものやろ
136デフォルトの名無しさん
2018/08/10(金) 17:01:03.73ID:r84RRSaO 誰かが例の記事のはてブで言ってたけど,ああいう人も必要だとは思う。
というか正直俺はプログラマじゃない(つまりコーディングで飯食ってるわけじゃない)ので,
ああいう考え方にはすごく興味があるし,実際研究室の管理シェルスクリプトをPOSIX準拠で書き直したりもしてる。
しかし繰り返すがプログラマにとっては邪魔な存在なんだろうなとは感じる。
というか言い方がキツすぎる。
というか正直俺はプログラマじゃない(つまりコーディングで飯食ってるわけじゃない)ので,
ああいう考え方にはすごく興味があるし,実際研究室の管理シェルスクリプトをPOSIX準拠で書き直したりもしてる。
しかし繰り返すがプログラマにとっては邪魔な存在なんだろうなとは感じる。
というか言い方がキツすぎる。
137デフォルトの名無しさん
2018/08/10(金) 17:59:17.69ID:q2LOavXt だが、それがいい。
138デフォルトの名無しさん
2018/08/12(日) 14:51:04.97ID:EQS0DV6K #!/bin/bash
for i in {0..5}; do
n=`date +%Y-%m-%d_%H '-d ${i} hour ago'`
echo $n
done
ループで時間を1時間ずつ過去にして表示したいんだけど実行すると
date: ` ${i} hour ago' は無効な日付です
て表示されます。
助け船おねがいします
for i in {0..5}; do
n=`date +%Y-%m-%d_%H '-d ${i} hour ago'`
echo $n
done
ループで時間を1時間ずつ過去にして表示したいんだけど実行すると
date: ` ${i} hour ago' は無効な日付です
て表示されます。
助け船おねがいします
139デフォルトの名無しさん
2018/08/12(日) 15:45:28.66ID:CtXb4bgk >>138
シングルクオートだと変数が、展開されない気がすダブルクォートにしてみて
シングルクオートだと変数が、展開されない気がすダブルクォートにしてみて
140デフォルトの名無しさん
2018/08/12(日) 17:45:18.75ID:EQS0DV6K141デフォルトの名無しさん
2018/08/13(月) 00:38:00.83ID:z6+TJcGX "-d ${i} hour ago" の部分が -d "${i} hour ago" ではないのに何故大丈夫なのかと思ったが、
短いオプションだからパラメータと繋がってても大丈夫ってことだったんだな。
短いオプションだからパラメータと繋がってても大丈夫ってことだったんだな。
142デフォルトの名無しさん
2018/08/14(火) 19:59:14.84ID:0dSYKDxo 上のやり取りをみてふと思いたって実験してみると
GNU dateではフォーマットにCSIとかに代表されるANSI制御綴りを指定できるけど
BSD dateでは無理だな。
POSIXではこの二つのどちらが正しい実装なのかはよく分からんが
個人的な意見としてはBSD dateのほうが堅牢で,GNU dateのほうが柔軟だとは思う。まあ当然すぎる事実だけどw
GNU dateではフォーマットにCSIとかに代表されるANSI制御綴りを指定できるけど
BSD dateでは無理だな。
POSIXではこの二つのどちらが正しい実装なのかはよく分からんが
個人的な意見としてはBSD dateのほうが堅牢で,GNU dateのほうが柔軟だとは思う。まあ当然すぎる事実だけどw
143デフォルトの名無しさん
2018/08/15(水) 02:35:15.09ID:sxh1cciH BSD date の仕様が分からないけど、標準出力が端末とは限らないし
指定そのまま出すほうが正しいんじゃないかな
指定そのまま出すほうが正しいんじゃないかな
144デフォルトの名無しさん
2018/08/15(水) 13:56:33.60ID:/R99sNfj 標準出力がなんのかんけーがあんのー?
145デフォルトの名無しさん
2018/08/15(水) 16:29:17.30ID:fSWxnCwv かんけーし
146デフォルトの名無しさん
2018/08/17(金) 03:06:26.97ID:DWhhxT1h 単純な文字列置換ってどうしたら良いですかね?
sedつかうとメタ文字の置換で困るんです
sedつかうとメタ文字の置換で困るんです
147デフォルトの名無しさん
2018/08/17(金) 03:42:44.91ID:l9m154d6 その辺りが楽なperlでいいんじゃない?
シェルスクリプトから使っちゃいけないというわけじゃないし
シェルスクリプトから使っちゃいけないというわけじゃないし
148デフォルトの名無しさん
2018/08/17(金) 04:16:11.31ID:DWhhxT1h149デフォルトの名無しさん
2018/08/17(金) 04:55:42.82ID:xP9ZimWn awk
150デフォルトの名無しさん
2018/08/17(金) 04:56:29.20ID:DWhhxT1h awkに正規表現じゃない文字列置換命令ってありましたっけ?
151デフォルトの名無しさん
2018/08/17(金) 06:24:27.95ID:/a+SCakG Ruby が簡単
152デフォルトの名無しさん
2018/08/17(金) 06:38:46.91ID:eWaVkn5S >>151
perlが無いならrubyも無いでしょ
perlが無いならrubyも無いでしょ
153デフォルトの名無しさん
2018/08/17(金) 07:03:28.31ID:DWhhxT1h はい、rubyもないし、pythonもなし、nodeもないです
154デフォルトの名無しさん
2018/08/17(金) 08:18:50.56ID:/a+SCakG Ruby をインストールすれば?
漏れは、WSL で、Rubyを入れているけど
漏れは、WSL で、Rubyを入れているけど
155デフォルトの名無しさん
2018/08/17(金) 08:24:08.77ID:RTbKyx/W156デフォルトの名無しさん
2018/08/17(金) 08:34:23.82ID:vhwq6spf viは?
157デフォルトの名無しさん
2018/08/17(金) 08:36:24.83ID:RTbKyx/W 手動で置換は嫌です
158デフォルトの名無しさん
2018/08/17(金) 08:40:03.28ID:vhwq6spf viはスクリプト組めるでしょ
159デフォルトの名無しさん
2018/08/17(金) 08:44:27.28ID:TmUZ5Zjz パターン文字列をsedで置換しちゃうとか(GNU sed の場合)
$ pattern='foo[1]'
$ sed "s/$(sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g' <<< "${pattern}")/foo[2]/g" <<< 'foo[1]'
foo[2]
$ pattern='foo[1]'
$ sed "s/$(sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g' <<< "${pattern}")/foo[2]/g" <<< 'foo[1]'
foo[2]
160デフォルトの名無しさん
2018/08/17(金) 08:49:02.25ID:vhwq6spf 脳みそが解読を拒否してる
161デフォルトの名無しさん
2018/08/17(金) 08:53:02.98ID:xP9ZimWn162デフォルトの名無しさん
2018/08/17(金) 08:56:35.86ID:RTbKyx/W >>158
スクリプトの実行はできましたが、 %s/〜/〜/g
だと〜に/が入っていた時に困ります。
〜には何が入るかわかりません。
あとviは標準入力から読み込めませんでした
できれば標準入力から読み込みんで標準出力に出力したいです。
ちなみにviのバージョンです
# vi -H
These features are available:
Pattern searches with / and ?
Last command repeat with .
Line marking with 'x
Named buffers with "x
Some colon mode commands with :
Settable options with ":set"
Signal catching- ^C
Job suspend and resume with ^Z
Adapt to window re-sizes
BusyBox v1.28.3 () multi-call binary.
Usage: vi [OPTIONS] [FILE]...
Edit FILE
-c CMD Initial command to run ($EXINIT also available)
-R Read-only
-H List available features
スクリプトの実行はできましたが、 %s/〜/〜/g
だと〜に/が入っていた時に困ります。
〜には何が入るかわかりません。
あとviは標準入力から読み込めませんでした
できれば標準入力から読み込みんで標準出力に出力したいです。
ちなみにviのバージョンです
# vi -H
These features are available:
Pattern searches with / and ?
Last command repeat with .
Line marking with 'x
Named buffers with "x
Some colon mode commands with :
Settable options with ":set"
Signal catching- ^C
Job suspend and resume with ^Z
Adapt to window re-sizes
BusyBox v1.28.3 () multi-call binary.
Usage: vi [OPTIONS] [FILE]...
Edit FILE
-c CMD Initial command to run ($EXINIT also available)
-R Read-only
-H List available features
163デフォルトの名無しさん
2018/08/17(金) 09:00:22.48ID:RTbKyx/W >>159
GNU sedじゃないからだめなんでしょうね
# pattern='foo[1]'
# sed "s/$(sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g' <<< "${pattern}")/foo[2]/g" <<< 'foo[1]'
-ash: syntax error: unexpected redirection
ちなみにsedの--versionと--helpです。
# sed --version
This is not GNU sed version 4.0
# sed --help
BusyBox v1.28.3 () multi-call binary.
Usage: sed [-i[SFX]] [-nrE] [-f FILE]... [-e CMD]... [FILE]...
or: sed [-i[SFX]] [-nrE] CMD [FILE]...
-e CMD Add CMD to sed commands to be executed
-f FILE Add FILE contents to sed commands to be executed
-i[SFX] Edit files in-place (otherwise sends to stdout)
Optionally back files up, appending SFX
-n Suppress automatic printing of pattern space
-r,-E Use extended regex syntax
If no -e or -f, the first non-option argument is the sed command string.
Remaining arguments are input files (stdin if none).
GNU sedじゃないからだめなんでしょうね
# pattern='foo[1]'
# sed "s/$(sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g' <<< "${pattern}")/foo[2]/g" <<< 'foo[1]'
-ash: syntax error: unexpected redirection
ちなみにsedの--versionと--helpです。
# sed --version
This is not GNU sed version 4.0
# sed --help
BusyBox v1.28.3 () multi-call binary.
Usage: sed [-i[SFX]] [-nrE] [-f FILE]... [-e CMD]... [FILE]...
or: sed [-i[SFX]] [-nrE] CMD [FILE]...
-e CMD Add CMD to sed commands to be executed
-f FILE Add FILE contents to sed commands to be executed
-i[SFX] Edit files in-place (otherwise sends to stdout)
Optionally back files up, appending SFX
-n Suppress automatic printing of pattern space
-r,-E Use extended regex syntax
If no -e or -f, the first non-option argument is the sed command string.
Remaining arguments are input files (stdin if none).
164デフォルトの名無しさん
2018/08/17(金) 09:16:35.01ID:RTbKyx/W165デフォルトの名無しさん
2018/08/17(金) 09:16:49.96ID:TmUZ5Zjz >>163
ああ、bash じゃなくて ash だから here string("<<<") が使えないのね…
# echo 'foo[1]' | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
こんな感じかな。
ああ、bash じゃなくて ash だから here string("<<<") が使えないのね…
# echo 'foo[1]' | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
こんな感じかな。
166デフォルトの名無しさん
2018/08/17(金) 09:33:56.45ID:xP9ZimWn167デフォルトの名無しさん
2018/08/17(金) 09:48:06.80ID:RTbKyx/W >>166
なんかプラスが入った時おかしいっすね
GNU sed
$ pattern='+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]
$ pattern='a+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]+
busybox sed
# pattern='+'
# echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
sed: bad regex '\+': Repetition not preceded by valid expression
なんかプラスが入った時おかしいっすね
GNU sed
$ pattern='+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]
$ pattern='a+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]+
busybox sed
# pattern='+'
# echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
sed: bad regex '\+': Repetition not preceded by valid expression
168デフォルトの名無しさん
2018/08/17(金) 09:57:27.72ID:TmUZ5Zjz169デフォルトの名無しさん
2018/08/17(金) 09:58:49.05ID:TmUZ5Zjz あ、ごめん勘違いしてた。ちょっと考えてみる
170デフォルトの名無しさん
2018/08/17(金) 10:03:14.53ID:RTbKyx/W そう。何が問題なのかよくわからないw
171デフォルトの名無しさん
2018/08/17(金) 10:13:01.82ID:TmUZ5Zjz あれ?でもさ、
pattern='+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]
入力が '+' でパターン文字列も '+' だから foo[2] に置換されるのは正しいんじゃないかな?
でもまぁ、GNU sed で -r オプション付けると `+` 記号がメタキャラクタになるから、付けない場合は
`+` を考慮する必要はなかったのね…
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
こっちの方が良いみたい。
pattern='+'
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*+^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
foo[2]
入力が '+' でパターン文字列も '+' だから foo[2] に置換されるのは正しいんじゃないかな?
でもまぁ、GNU sed で -r オプション付けると `+` 記号がメタキャラクタになるから、付けない場合は
`+` を考慮する必要はなかったのね…
$ echo "$pattern" | sed "s/$(echo "${pattern}" | sed -r 's/([-*^.$/\]|\[|\])/\\\1/g')/foo[2]/g"
こっちの方が良いみたい。
172デフォルトの名無しさん
2018/08/17(金) 10:13:20.76ID:5I+JCiH1173デフォルトの名無しさん
2018/08/17(金) 10:18:32.56ID:RTbKyx/W174デフォルトの名無しさん
2018/08/17(金) 10:20:29.64ID:RTbKyx/W だから要するに + はエスケープしたらダメってことなのか?
単純な文字列置換って正規表現置換よりも簡単な処理なのに
どれも面倒くさいなぁw
単純な文字列置換って正規表現置換よりも簡単な処理なのに
どれも面倒くさいなぁw
175デフォルトの名無しさん
2018/08/17(金) 10:33:33.58ID:hKcJGgnp ashの日本語manページはないのかなと思って検索した時に出てきた画面。
https://i.imgur.com/xzEhcAc.png
https://i.imgur.com/xzEhcAc.png
176デフォルトの名無しさん
2018/08/17(金) 10:37:43.83ID:RTbKyx/W177デフォルトの名無しさん
2018/08/17(金) 10:41:51.16ID:hKcJGgnp >>176
カラフルな検索結果だがこれと言って役に立たないという共通点があるな・・・
カラフルな検索結果だがこれと言って役に立たないという共通点があるな・・・
178デフォルトの名無しさん
2018/08/17(金) 10:51:57.16ID:RTbKyx/W179デフォルトの名無しさん
2018/08/17(金) 11:32:47.25ID:TmUZ5Zjz grep にある -F オプションと同等のオプションが sed にも
欲しいところではあるなぁ。生まれは同じなのに sed には無い
のは何故…(実はあったりして)
欲しいところではあるなぁ。生まれは同じなのに sed には無い
のは何故…(実はあったりして)
180デフォルトの名無しさん
2018/08/17(金) 18:50:11.51ID:D/YAmHXf fsedみたいなのを作ってる人ならしってる
181デフォルトの名無しさん
2018/08/18(土) 17:22:09.36ID:rQWtSS3z Googleのシェルスクリプトに関するコーディング規約で
「そう〔訳注: 連続したパイプ節が二つ以下〕でない場合は一行につき一つのパイプ節を含むようにする。その際,二番目以降のパイプ節は,2文字分の欧文空白による字下げを行なう。」
とあるんだが[1],ここの例示が
command1 \
| command2 \
| command3 \
| command4
となっている。
普通(といってもパイプをこのように多用しかつ改行しまくっている例はほとんど見たことがないのだが)https://github.com/ShellShoccar-jpn/kotoriotoko/blob/master/BIN/twtl.sh#L297
↑こことかでは
command1 |
command2 |
command3 |
command4
という書き方になっている。
俺はこっちの書式のほうが見慣れているので,自分のシェルスクリプトもこういう書き方でやっているのだが,みなさんはどういう書き方がいいとかあるだろうか。あるいはGoogleとは別のところが発表してるシェルスクリプトのコーディング規約とかないだろうか。
「そう〔訳注: 連続したパイプ節が二つ以下〕でない場合は一行につき一つのパイプ節を含むようにする。その際,二番目以降のパイプ節は,2文字分の欧文空白による字下げを行なう。」
とあるんだが[1],ここの例示が
command1 \
| command2 \
| command3 \
| command4
となっている。
普通(といってもパイプをこのように多用しかつ改行しまくっている例はほとんど見たことがないのだが)https://github.com/ShellShoccar-jpn/kotoriotoko/blob/master/BIN/twtl.sh#L297
↑こことかでは
command1 |
command2 |
command3 |
command4
という書き方になっている。
俺はこっちの書式のほうが見慣れているので,自分のシェルスクリプトもこういう書き方でやっているのだが,みなさんはどういう書き方がいいとかあるだろうか。あるいはGoogleとは別のところが発表してるシェルスクリプトのコーディング規約とかないだろうか。
182デフォルトの名無しさん
2018/08/18(土) 17:22:24.47ID:rQWtSS3z 一応俺の意見: 後者の利点としては,バックスラッシュが不要なこととコマンドが行頭に来て流れを掴みやすいということがある。
加えて簡易的なデバッグするときに,前者は
command1 \
| command2 \
| cat
# | command3 \
# | command4
などとするのに対して 後者は
command1 |
command2 |
cat
# command3 |
# command4
このように「新しい行を挿入してcatを入力」という単純な動作ができるので,例えばVimやEmacsなどマクロが作れるエディタなどでのデバッグ用の編集に有用というのもある。
実際俺はシェルスクリプトに関してはIDEを使わずVimで開発していて,この類のマクロを作成して便利に使っている。
長文すまん
[1]: http://google.github.io/styleguide/shell.xml#Pipelines
加えて簡易的なデバッグするときに,前者は
command1 \
| command2 \
| cat
# | command3 \
# | command4
などとするのに対して 後者は
command1 |
command2 |
cat
# command3 |
# command4
このように「新しい行を挿入してcatを入力」という単純な動作ができるので,例えばVimやEmacsなどマクロが作れるエディタなどでのデバッグ用の編集に有用というのもある。
実際俺はシェルスクリプトに関してはIDEを使わずVimで開発していて,この類のマクロを作成して便利に使っている。
長文すまん
[1]: http://google.github.io/styleguide/shell.xml#Pipelines
183デフォルトの名無しさん
2018/08/18(土) 18:05:23.17ID:5BnyFmRJ 簡易的なデバッグするときに前者は
command1 \
| command2 \
# | command3 \
# | command4
などとするのに対して 後者は
command1 |
command2 |
# command3 |
# command4
のように行頭に#をいれるだけではSyntax errorになるから前者の方がデバッグなど編集に有用とも言える
個人的には大差ないと思う
command1 \
| command2 \
# | command3 \
# | command4
などとするのに対して 後者は
command1 |
command2 |
# command3 |
# command4
のように行頭に#をいれるだけではSyntax errorになるから前者の方がデバッグなど編集に有用とも言える
個人的には大差ないと思う
184デフォルトの名無しさん
2018/08/18(土) 18:29:20.16ID:LW/iu6SG 末尾にバックスラッシュを入れることで次行を見なくても明確にコマンドが続くことがわかるから前者を支持する
185デフォルトの名無しさん
2018/08/18(土) 18:38:12.95ID:Bu4pj5O8 一長一短やな
使い分けか
使い分けか
186デフォルトの名無しさん
2018/08/18(土) 19:19:56.79ID:rQWtSS3z187デフォルトの名無しさん
2018/08/18(土) 19:21:44.26ID:rQWtSS3z ていうか少なくとも二人くらいは
後者の方式に賛同してるのか。
Googleもそっちを推奨してるし,俺も手癖を直すべきなのかな。
後者の方式に賛同してるのか。
Googleもそっちを推奨してるし,俺も手癖を直すべきなのかな。
188デフォルトの名無しさん
2018/08/18(土) 20:18:01.73ID:pAmB63kN189デフォルトの名無しさん
2018/08/18(土) 21:09:33.95ID:bNUWoVQ1 パイプ記号が重要だから頭にもってきたいかなあ
190デフォルトの名無しさん
2018/08/19(日) 00:41:34.89ID:6q4oK8R8 scsh 使え https://scsh.net/about/what.html
191デフォルトの名無しさん
2018/08/19(日) 01:23:37.19ID:A4xH6fb7 バックスラッシュで行継続(改行)って多くの言語で採用されているから
多くの人はパイプ先頭、バックスラッシュ行末じゃないかな?
多くの人はパイプ先頭、バックスラッシュ行末じゃないかな?
192デフォルトの名無しさん
2018/08/19(日) 02:52:07.69ID:YqoTvka6 俺は1行か2行くらいなら後者だな。
何行もずらずら並べるなら中括弧で囲んでパイプ記号を先頭に持ってくるかも。
行末にバックスラッシュを置いて行継続はあまり美しくないと思うのでなるべく書きたくない。
>>191
構文的に行末で文(言語によっては式)が完結できていれば行末を文の終わりとみなし
そうでなければ次の行に継続、というのもshそのものをはじめpython, JavaScriptなど多くの言語で採用されているよ。
(pythonはshと同じく行末バックスラッシュで継続もできるが)
更にRubyは行の終わりで完結できるように見えても次の行の先頭を見てどうするか決めていたりする。
何行もずらずら並べるなら中括弧で囲んでパイプ記号を先頭に持ってくるかも。
行末にバックスラッシュを置いて行継続はあまり美しくないと思うのでなるべく書きたくない。
>>191
構文的に行末で文(言語によっては式)が完結できていれば行末を文の終わりとみなし
そうでなければ次の行に継続、というのもshそのものをはじめpython, JavaScriptなど多くの言語で採用されているよ。
(pythonはshと同じく行末バックスラッシュで継続もできるが)
更にRubyは行の終わりで完結できるように見えても次の行の先頭を見てどうするか決めていたりする。
193デフォルトの名無しさん
2018/08/19(日) 04:00:58.03ID:O9LemqF2194デフォルトの名無しさん
2018/08/19(日) 16:16:41.68ID:L67BZdE+ shに限らず末尾に演算子を置く
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 【サッカー】2026年北中米W杯の組み合わせが決定! 日本代表はオランダ、チュニジア、欧州プレーオフB勝者と同組で激突★2 [久太郎★]
- 渡邊渚「性を売ってるくせに」批判に反論 幻滅「これが日本の現状だよなー」「『渾身の下着!』というような意味でやってない」★2 [Ailuropoda melanoleuca★]
- 【千葉】会社で58歳女性刺される 殺人未遂容疑で同僚の中国籍の男(39)逮捕 女性死亡 いすみ市 [ぐれ★]
- 渡邊渚さん脅迫か 写真集に包丁置く写真投稿 30代女性書類送検 渡邊さん「外に出るのも怖く身の危険を感じる」 [ひかり★]
- 【生成ポルノで初】AI生成の児童ポルノ画像の所持疑いで元教諭を初摘発… [BFU★]
- 鈴木農相、地元JAから借入金 おこめ券巡り利害誘導との批判も★2 [安倍聖帝★]
- 【01:45NHK~】サッカーW杯2026グルーブ分け組み合わせ抽選会いよいよスタート! ★2 [339712612]
- 【NHK/DAZN/YouTube】FIFAワールドカップ2026組み合わせ抽選★3
- 【朝日新聞】クラウドワークス、「中国批判」「嫌中」などネトウヨ動画制作の依頼を少なくとも14件募集 [718678614]
- 識者「2002年はインターネット黎明期。パソコンがワープロの代わりだと思われていた時代」 [932029429]
- すまん、人を殺すことになんの躊躇もないサイコパスなんやが🥺
- 【悲報】高市早苗に似てる人が中国でお菓子のパッケージになる [884040186]
