X



シェルスクリプト総合 その26 [無断転載禁止]©2ch.net
■ このスレッドは過去ログ倉庫に格納されています
0001名無しさん@お腹いっぱい。
垢版 |
2017/03/20(月) 12:07:26.41
シェルスクリプトの総合スレです。
□お約束
・特記なき場合はBourne Shell(/bin/sh)がデフォルトです。
 bash/zsh/ksh/ashなどに依存する場合は明示しましょう。
 Linuxユーザは/bin/shの正体がbashまたはdashなので特に注意。
 FreeBSDユーザは/bin/shの正体がashなので注意。
 v7 shに一番近くて、現役のshは、OpenSolaris由来のheirloom sh。
  http://src.illumos.org/source/xref/illumos-gate/usr/src/cmd/sh/
  http://heirloom.sourceforge.net/sh.html
・csh/tcshのシェルスクリプトは推奨されません。
 (理由は「csh-whynot」でググれ)
・UNIXにはシェルスクリプトに便利な小さなコマンドがいろいろあります。
 manや参考リンクを見ましょう。
 aproposないしはman -kでそれらしい単語による簡単な検索もできます。
・シェルで使えるワイルドカード等は正規表現ではありません。
 正規表現の話題はスレ違い(正規表現スレへ)
・シェルスクリプトのことをシェルってゆーな
□初心者へのアドバイス:
・適した道具を判断するのも頭の重要な使い方。シェルスクリプトよりも
 awkまたはperlの方が適した処理にはそちらを使いましょう。
・知らないコマンドが出てきたらmanを引きましょう。
・思い通りに動かないときは、まずは sh -x でトレースしましょう。
□回答者への注意事項:
・シェルスクリプトでの処理方法を質問しているのに、よくわからずに
 「そういうのはperl使いましょう」と回答するのはやめましょう。
 安易にperlに逃げずにシェルスクリプトで処理するのが頭のいいやり方。
前スレ
シェルスクリプト総合 その25
http://echo.2ch.net/test/read.cgi/unix/1439563321/
0052名無しさん@お腹いっぱい。
垢版 |
2017/04/04(火) 11:29:13.28
知らんけど推測で。

1-a. シェルが hoge.txt を O_WRONLY(?) | O_TRUNC とかでオープン (O_TRUNC なので 0バイトになる)
1-b. シェルが cat hoge.txt fuga.txt を exec
1-c. cat が hoge.txt をオープンするも、0バイトなので実質何もしない。
1-d. cat が fuga.txt をオープンして標準出力に出力。

2-a. シェルが hoge.txt を O_WRONLY(?) | O_APPEND でオープン。
2-b. cat が hoge.txt をオープンし、読み込んだものを標準出力に出力。
2-c. 読み込むと、直前に書いたものが読み込めてしまうので永遠に終わらない。

2の挙動は知らんかったなぁ。
0055名無しさん@お腹いっぱい。
垢版 |
2017/04/04(火) 12:16:42.64
これは無限ループにもエラーにもならない

$ cat hoge.txt | cat >> hoge.txt

しかし、ファイルサイズがパイプやプロセスのバッファサイズを
超えるとどうなるか…こんな場合は moreutils の sponge コマンドかな
0059名無しさん@お腹いっぱい。
垢版 |
2017/04/13(木) 16:40:20.18
sqlplusでselect文を実行したときにレコードが該当しない場合の値って何が返されるの?
予想だと""なんだけど
0060名無しさん@お腹いっぱい。
垢版 |
2017/04/13(木) 17:33:03.18
>>59
俺は SELECT 結果の行数をカウントして判定してる。

ちなみにシェルスクリプトで sqlplus をカプセル化しようとすると、SQL 実行時のエラーチェックが地味に面倒だよね。
頑張ってね。
0061名無しさん@お腹いっぱい。
垢版 |
2017/04/13(木) 17:57:28.60
>>60
count(0)ですねわかります
シェルスクリプトってsqlで取ってきた値がnullのときその値を変数に格納したらどうなんの?
そもそもselect文で該当なしでエラーになるのかもわからん
0062名無しさん@お腹いっぱい。
垢版 |
2017/04/13(木) 18:02:46.69
なんでこんなこと聞くのって思うだろうけどprintfで書式指定するときにnullが変えるかもしれない変数を%08d$nで指定してるんだよね
文字列指定してけば良かったんだけど、これって修正必要かなぁ
0063名無しさん@お腹いっぱい。
垢版 |
2017/04/13(木) 18:51:39.93
>>61
違う違う。SPOOL で SELECT 結果をファイルに保存し、そのファイルの行数を wc -l でカウントするイメージです。
いろいろとやり方があると思うけど、私の場合は項目区切りを TAB でレコード区切りを改行にして SELECT 結果を TSV ファイル化することが多い。
んで、そのファイルをシェルで一行ずつ読み込みながら必要に応じて処理する感じ。awk で各項目の値をバラすのがラクチン。

NULL 値は、フツーに処理してれば特に意識してなくても空文字列としてシェルスクリプトの変数に入るはず。

あと SELECT COUNT(*) を実行するケースも無いではないけど、その結果が 0 でない場合はもう一度 SELECT するってこと?
クエリを二度実行するコストは容認できないケースが多いと思います。
もちろん、SELECT 結果の有無のみが必要なケースなら SELECT COUNT(*) した結果が 0 かどうかで判定するのはアリです。

>>62
もうちょっと具体的に説明してもらわないと分からないけど、例えば SELECT name FROM emp WHERE id=1; の結果が NULL だと困るのなら……
実行するクエリを SELECT NVL(name, '(NULLだよ)') FROM emp WHERE id=1; みたいに変更すればいいだけじゃね?
0065名無しさん@お腹いっぱい。
垢版 |
2017/04/14(金) 18:54:35.33
澁谷 恭正 (46歳)

千葉県立沼南高柳高等学校卒

松戸市立六実第二小学校PTA会長

小学女子レイプ殺人で逮捕


お住まい:
千葉県松戸市六実4-8-1 Mシャトレ

お子さん:
ひりゅう、あやか ※父子家庭

趣味傾向:
アニオタ
0066名無しさん@お腹いっぱい。
垢版 |
2017/04/14(金) 18:55:56.71
SQL*Plus、PL/SQLに詳しくないからそういう発想になるのはわかるが、普通にやれよ。
0067名無しさん@お腹いっぱい。
垢版 |
2017/04/15(土) 15:48:43.00
>>66
普通ってやんだよw
0068名無しさん@お腹いっぱい。
垢版 |
2017/04/15(土) 17:42:26.47
シェルとsqlplus触ったの1,2ヶ月だけど、半年後にはおまえ超えてるから
0069名無しさん@お腹いっぱい。
垢版 |
2017/04/15(土) 17:43:22.15
シェルなんてゴミ言語勉強するほどでもないけどなw
0070名無しさん@お腹いっぱい。
垢版 |
2017/04/15(土) 18:11:52.36
クエリを2度実行するコストよりもってあるけど、コストそんなかからないし、どっちでもよくね。
sqlじたいそんな詳しくなくてすまんな
0071名無しさん@お腹いっぱい。
垢版 |
2017/04/15(土) 18:15:32.21
ワンステップでどんだけコストかかる現場にいたのか
0073名無しさん@お腹いっぱい。
垢版 |
2017/04/15(土) 18:53:59.01
これはステップ数大きいけど、たしかおれは2ステップで書いた
0074名無しさん@お腹いっぱい。
垢版 |
2017/04/16(日) 03:11:26.19
>>72
なんで例外処理でやらないのか?
基本中の基本だぞ。
0075名無しさん@お腹いっぱい。
垢版 |
2017/04/16(日) 13:19:14.99
>>74
だからやってるって話だよ
バカなの
0076名無しさん@お腹いっぱい。
垢版 |
2017/04/16(日) 13:20:30.64
シェルでカプセル化とかもわけわからんし、このスレわからんわ
0078名無しさん@お腹いっぱい。
垢版 |
2017/04/17(月) 16:49:07.58
$ for d in /bin /usr/bin /sbin /usr/sbin ; do echo -n "$d: " ; file $d/* | fgrep 'shell script' | wc -l; done
/bin: 25
/usr/bin: 290
/sbin: 12
/usr/sbin: 57
意外とあるな
0081名無しさん@お腹いっぱい。
垢版 |
2017/04/18(火) 17:45:32.71
>>80
ほほう -d オプションというものがあるのか……と思ったんだけど、これって bash のみだったりする?
手元の古い tcsh には無いみたい。それとも最近のシェルなら普通に実装されてるのかな。
0083名無しさん@お腹いっぱい。
垢版 |
2017/04/19(水) 12:00:20.42
>>78
こういうのって、fgrepにIをつけたほうがいいのかな。
0085名無しさん@お腹いっぱい。
垢版 |
2017/04/19(水) 12:41:43.72
>>84
ありがとうございます
昔、binの中等気をつけろと言われた事があったので勘違いしてました
0086名無しさん@お腹いっぱい。
垢版 |
2017/04/19(水) 16:28:25.43
>>75
なんでexceptionでno_data_foundを拾わないのか?

カウントしてしまうのは、不慣れなひとがよくやるけど。
0091名無しさん@お腹いっぱい。
垢版 |
2017/04/21(金) 17:16:08.95
>>88
え?
0092名無しさん@お腹いっぱい。
垢版 |
2017/04/21(金) 18:35:17.79
この中で過去にシェルを仕事でやってたって人何人くらいいるのかな
0093名無しさん@お腹いっぱい。
垢版 |
2017/04/21(金) 21:31:36.96
自分はインフラ関連やってたよ
今は仕事ではコンソール触ることはなくなったけど
家で動画ダウンロード用のスクリプト組んだりしてる
0094名無しさん@お腹いっぱい。
垢版 |
2017/04/21(金) 21:34:59.83
ちなみに性能情報の収集や監視スクリプト、
バックアップとかの運用シェル作ってたけど
可読性も考えてオーソドックスなプログラミングのような書き方をしてたから
超何かよく分からん使い方をしてるココの人の方がシェルスクリプト知ってると思う
0095名無しさん@お腹いっぱい。
垢版 |
2017/04/22(土) 04:52:18.92
>>94
よくわからない書き方してるほうが上手いとも言えないでしょ
0096名無しさん@お腹いっぱい。
垢版 |
2017/04/22(土) 04:53:18.13
linuxってちゃんと使いこなせれば快適だよなすごいわかる
0097名無しさん@お腹いっぱい。
垢版 |
2017/04/22(土) 05:55:28.79
>>92
shだけの仕事は数えるほどしかないけど
他の仕事の小道具として毎回のように出てくるな
javaとかwindows系の仕事だと使えなくてめんどくさい
開発ツールとしては使うけど
0099名無しさん@お腹いっぱい。
垢版 |
2017/04/22(土) 19:43:27.62
>>98
めずらしいとは思ってないけどさ、働いてないのかと思った。
何かしら経験ある人もいるのな、仕事で使ってて家でもシェルいじろうとかよく思えるな
0104名無しさん@お腹いっぱい。
垢版 |
2017/04/24(月) 16:02:53.74
他紙蟹
わかったからそんなせめんなよごめんなっっ
家でシェル使ってる人ってwindows機は別にあるの?
0105名無しさん@お腹いっぱい。
垢版 |
2017/04/24(月) 17:31:59.58
あるよ、自分はWindowsなんて使わないという偏屈ではないしさ
Linuxの実機はラズパイだけであとは仮想環境
まあ他にも色々あるけど実際に使ってる環境ってことならね
>>103を書いたのは嫌気がさして書いたんじゃなくて
目的や知識がないとシェルなんて触る機会もないでしょって意味で書いた
0106名無しさん@お腹いっぱい。
垢版 |
2017/04/24(月) 17:49:44.72
ubuntu on the windowsのおまえらの率直な感想が聞きたい
0112名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 00:43:15.05
>>109
やるじゃんそーゆー振り切ってる感じ好きだぜ
0113名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 00:49:06.70
>>111
そうは言ってなかったな、シェルなんて職場で使わなきゃやろうと思わないでしょって言ってたよ
0114名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 00:51:05.94
ぶっちゃけLinuxだけだと不便やねん、だからどっちもいるねん、必須なのはWindowsやねん、結局便利だけどLinuxは無くてもいけるねん
0116名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 01:15:23.26
>>113
仕事も勉強も関係なくエロ画像収集に使うだろ
初めてはSSIとかCGIだったな
ISPでシェルアカウント付きのとこもあった
やらされてるだけの人には価値はわからんだろうけど
0118名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 05:48:06.67
>>116
VBとかで出来るからね
シェルを使うにはUnix環境が必要で
知識ゼロのニートが自主的にやったってのは知らないなあ
Unix界隈に居る人って性格悪いじゃん?
そんな中で続くとは思えないんだけど

学生か働いてる(働いてた)時に得た知識でやるならわかるけどさ
0119名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 06:14:57.29
画像収集ツールって昔からいくつかあるけど
それを使わずにシェルスクリプト使った人が今何してるのか興味あるな

自分はOSもアプリも言語も道具だから何でもいいんだけど
獲得したものを特別なものと思って他人を見下すってのは余裕のない感じがするね
そのあたりがLinuxが流行らなかった理由なんじゃないかと思う
スマホ使ってる人なんてニコニコしながら嫌味無く教えてくれるときあるしw
0120名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 06:32:05.73
やらされてるだけの人って嫌味なんだろうけど
ココで答えてくれてる人はそんな人なこと忘れてるよ
失礼な奴だな
0121名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 09:39:07.19
シェルスクリプトを作れない人がやっかんでるだけに見えるな

画像収集ツールみたいなことをする場合、Windowsアプリも
cygwonでシェルスクリプト+コマンドのパターンも使う
一方しか出来ない人は時間を損してると思うよ
0122名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 09:44:08.16
暇つぶしに聞いただけだろう
現役で職場でシェルスクリプト使う身からすると奇妙な質問には思えるが
これがCOBOLとかなら話分かったけど
0123名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 10:09:42.40
>>118
Unix界隈の人は性格悪いってま?
0125名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 10:29:48.93
画像収集ツールってWindowsで動く既存アプリがいくつもあるんだよ〜
自分はシェルスクリプトを否定はしていない

でも学んでも働いても無かった人(要するにシェルを使ってなかった人)が
画像収集するためにいきなりシェルを使うとは思えないんだな
シェルスクリプトに行き着くためには
UnixなりりLinuxなりCygwin、BoW、Services for UNIXが必要になるわけであって
画像収集するのに便利って言うのは違和感がある
そういう人が本当に使ってるとして今どのレベルなのかも興味があるね

まだ画像収集レベルなのかな?

まあ別に目的を達せられたら良いんだけどね(で振り出しに戻ると)
0126名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 10:31:54.24
ちなみに自分は学んだし仕事でやってたよ
だから実装は楽だしやらせたいことを自動でやらせるためにスクリプト組んでるね
0127名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 10:40:20.49
すまん、結局何が言いたいのか分からん
これは単にシェルスクリプト使ってるのを見下したいだけなのか?
0128名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 10:46:20.83
自分が使える道具を、使うと何かの目的が達せられるところで使うだけだよ
環境、能力、目的は人によるから想像力の欠如をアピールしてもしょうがない
0129名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 11:20:26.09
>>118
CGIやSSIやISPはweb関連だ
wwwの世界はUnixばかりだからな
で何もなかった昔のwwwではCGIの設置改造とか普通
どうやって動いてるのかとか興味を持って調べた奴も多いだろう
つまり趣味で知った奴もいるってことだ

昔はWindowsでもcygwinとかでシェル使ってたけどな
今はないのかな
VBのツールのメンテとかもしてたけどUnixが吐くデータの処理だったからshで置き換えて効率化したな

やらされてる奴に性格悪い奴がいることはわかった
0133名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 14:42:58.20
>>105
ラズパイってむずい?
0135名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 15:04:11.72
>>130
VBのツールの置き換えは仕事だぞ
趣味はお金払ってでもするものだけどな
ただUnixワークステーションとか買えねえよ
0141名無しさん@お腹いっぱい。
垢版 |
2017/04/25(火) 17:53:50.03
開発経験者が趣味でシェルスクリプト書くって普通だと思う
てっきり営業とか企画とか別分野の人がシェルスクリプト書いたのかと思った
■ このスレッドは過去ログ倉庫に格納されています

ニューススポーツなんでも実況