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

レス数が1000を超えています。これ以上書き込みはできません。
2019/10/25(金) 00:08:45.53ID:6btPTvif
シェルスクリプトに関する総合スレッドです。

全般
・荒しは無視しましょう。
・丁寧な姿勢を心掛けましょう。
・ネチケット(死語)を意識しましょう。
・「○○(他の言語)でいいやん」は禁止。他のスレに行ってください。

シェルスクリプト総合 その31
https://mevius.5ch.net/test/read.cgi/tech/1565446670/
2020/03/22(日) 07:52:15.98ID:7aOor4nW
>>958
じゃあ何で分けるのさ?
2020/03/22(日) 09:08:29.58ID:c5TE3idF
>どんな言語だって1つの関数が100行超えるようならやめるべきだし
を何度読んでも、そのとおりとしか?
2020/03/22(日) 10:24:47.84ID:I5Su+SV6
GoogleのStyle Guideには100行超えるようなスクリプトを書いてるなら
今すぐもっと構造化された言語で書き直すべきって書いてる

>If you are writing a script that is more than 100 lines long,
>or that uses non-straightforward control flow logic,
>you should rewrite it in a more structured language now.

関数の長さじゃなくスクリプトの長さの話
似てるけど持ってる意味合いが違う
2020/03/22(日) 12:56:41.04ID:tFupwLj7
シェルスクリプトも十分構造化されてると思うんだけどねぇ。
まあ,Pythonとかに比べれば,メッソドや継承とかそういう概念が備わってない意味では低級だけど,

「シェルスクリプトで巨大なプログラムを書くべきでない理由」として
「シェルスクリプトは*構造的*でないから」ってのはちょっと頂けない。
シェルスクリプトには構造化プログラミングを支援する機能(函数定義,局所変数)が備わってる以上,
構造化されてないシェルスクリプトがあったならそれは書いた人間の責任であって,
もっと言うとそういうシェルスクリプトを書くような人間は,
Pythonであっても,用意されたオブジェクト指向の機能なんて使わずに,ひたすら手続き的なプログラムを書くだろう。
2020/03/22(日) 13:04:15.24ID:c5TE3idF
>>962
そういうことだよね。
シェルスクリプトで書いたそのコードを
他の言語で書いたところで、ロジックが同じなら行数も同じ
2020/03/22(日) 14:10:38.21ID:An20OwGu
>>952
懇切丁寧な解説が初心者向けじゃないなら何なのさ
常識しか載ってなくてつまらなかった?
2020/03/22(日) 14:27:24.29ID:Hw+To0D5
何を絡んでいるんだか
2020/03/22(日) 14:32:07.41ID:Hw+To0D5
結論、初心者も視野に大いに入っている規約。ある意味初心者に合わせた
だから、100行についてあれこれ議論してもしょうがないよ、Googleにコード提供するわけでもなし変だと思うならふーんと無視だなw
2020/03/22(日) 15:21:02.01ID:I5Su+SV6
>>962
同じロジックでも行数は全然違ってくるよ
shやbashには型がないのと原始的エラーハンドリング機構しかないのが大きい

他にも高階関数がまともに書けないし
一般的な言語に用意されてる便利メソッドもないし
モジュール化機能も関数とファイル以外に無い

読みやすさ、メンテしやすさ、テストのしやすさの点から
シェルスクリプトの限界を認識して節度を持って使おうねってのが
Googleのガイドの意図だと思う
2020/03/22(日) 15:21:37.48ID:I5Su+SV6
>>967
アンカ間違えた
2020/03/22(日) 15:48:56.43ID:c5TE3idF
>>967
型がないのは他にも有るだろ
エラーハンドリングも例外がない言語はいくらでもある
高階関数はevalで関数をよびだすことができるので同等のことは出来る
メソッドはオブジェクト指向じゃないから関数として
外部コマンド=シェルスクリプトの関数なんだからたくさんある
モジュール化機能って関数とファイル以外に何が必要なんだ?

> シェルスクリプトの限界を認識して
その限界の理由がはっきり書かれてない。

読みやすさが悪い、メンテしやすさが悪い、テストのしやすさが悪い
という"結論"を言ってるが理由がない
2020/03/22(日) 16:56:26.48ID:I5Su+SV6
>>969
>型がないのは他にも有るだろ
例えば?

>エラーハンドリングも例外がない言語はいくらでもある
最近の言語で例外もパターンマッチもないのはGoくらい
Goはそれもあって同じことする場合でも他言語よりも行数が多くなりがち
それでも型と多重代入があるからシェルスクリプトよりはマシ

>高階関数はevalで関数をよびだすことができるので同等のことは出来る
それがまともに書けるという認識なら何を言っても無駄っぽいね
どうぞシェルスクリプトで頑張ってください
2020/03/22(日) 17:17:48.98ID:I7uR5y3I
>>969
機能がある/ない、できる/できないの2択の話でなくて、規模が大きくなったり構造が複雑になったらそれに適した使いやすい言語を使うと良いというだけの話だろうに。
2020/03/22(日) 17:52:07.84ID:9SijoV71
シェルスクリプトの可読性・保守性について問題ないと思ってる人ってシェルスクリプト以外でコード書いてないのだろうとしか思えない
2020/03/22(日) 18:47:11.03ID:Hw+To0D5
誰もそんなこと言ってないと思うけど
2020/03/22(日) 22:29:55.52ID:c5TE3idF
>>970
> 例えば?
Perl

> 最近の言語で
いきなり言い訳から入るスタンスかw C言語もないですよね

> それがまともに書けるという認識なら
反論できてないじゃんw

>>971
そこに行数は関係ないよね。やってることが同じなら他の言語に変えても同じこと
2020/03/22(日) 22:31:28.16ID:c5TE3idF
>>972
言語で何かが標準サポートされないと
可読性や保守性を保てないんでしょ?

可読性や保守性なんて言語関係ないのに
自分に能力がない理由を言語のせいにするな
2020/03/22(日) 23:46:42.00ID:I5Su+SV6
>>974
>Perl
Perlには型あるよ
型の有無も分からないレベルなら比較しても意味ないから
もう少しプログラミング言語を勉強してから出直してくれ
2020/03/23(月) 00:00:17.14ID:FfORFm5F
>>976
配列とか数値なら、シェルスクリプトにもありますよw

man basnより

declare [-aAfFgilrtux] [-p] [name[=value] ...]
-a 各 name は配列変数です (前述の 配列 を参照)。
-A 各 name は連想配列変数です (前述の 配列 を参照)。
-i 変数を整数として扱います。
2020/03/23(月) 00:28:12.94ID:nPflIkhM
basn ってw 落ち着けよw
2020/03/23(月) 00:30:27.51ID:FfORFm5F
どうでもいい指摘はいらんがな
2020/03/23(月) 01:15:14.84ID:TYte82vJ
次スレ

シェルスクリプト総合 その33
https://mevius.5ch.net/test/read.cgi/tech/1584893550/
2020/03/23(月) 01:16:08.21ID:nPflIkhM
訂正しとけよw
2020/03/23(月) 10:39:17.98ID:iyDg9ARV
>>977
>配列とか数値なら、シェルスクリプトにもありますよw

型がどういうものか何も知らないんだな
マジでもう少し勉強したほうがいいよ

結局シェルスクリプトしかできなくて他の言語使えと言われると困るから
「シェルスクリプトでもできるもん」て必死に言い訳してるだけ
VBAしかできないVBAerと同じで完全に老害だぞ
2020/03/23(月) 10:58:57.53ID:pXU5nyzo
あくまで「効率的に」できるかどうかの話をしているはずなのになぜか言語仕様上できるかで語るからおかしなことになる
2020/03/23(月) 12:00:16.76ID:nemSJghh
「(俺はシェルスクリプトしか書けないから)シェルスクリプトで書くのがもっとも効率的だ」
2020/03/23(月) 12:53:13.68ID:SU+/TFOc
>>982
ある言語に型がある、って、どういう挙動をしたらそう言えるの?
Bashでは事実「これは整数だよ」と(少なくともプログラマに対して)そう言えるんだけど、それじゃだめなの?
逆にPythonは変数宣言する時に型を明示しなくてもいいけど
一般に「型を持つ」って言われるよね。
2020/03/23(月) 13:15:59.08ID:cSlylFOX
それはちょっと違うな
双方とも、話が噛み合ってなさすぎ
2020/03/23(月) 13:17:16.43ID:xNveXtQI
比較検討の対象範囲が狭い人が堕ちる地獄だね
傍から見ると、視認可能な穴に自ら飛び込んでいるように映る
2020/03/23(月) 13:55:21.04ID:1yvBsEB/
>>982
声が震えてるぞw

知らないんだな(くっ何も言い返せない)
捨て台詞かよwww
自称知ってるお前さん、ちゃんと説明してみぃ?
2020/03/23(月) 13:56:23.56ID:1yvBsEB/
>>983
効率的に出来なかったら何がだめなのか?
今の話に「効率」がどう関係するのか?
説明は?
2020/03/23(月) 14:38:42.12ID:OwPrjqjt
>>932
> 型がどういうものか何も知らないんだな
> マジでもう少し勉強したほうがいいよ

説明なしに相手をディスるだけのレスはやめとけ
マウント取れないし、捨て台詞的で負けを認めたと取られかねない
仮にマウント取れても所詮匿名の掲示板なんで dat 落ちすればそれまで


>>989
> 今の話に「効率」がどう関係するのか?

話の発端は「もっと構造化された言語で書き直すべき」でしょ?
揚げ足取りするなとは言わんが本題を忘れるほど熱中すんな
2020/03/23(月) 14:41:24.44ID:cOy+SXou
>>990
シェルスクリプトが得意な分野
(コマンドの組み合わせで行う処理)は
シェルスクリプトが一番効率がいいんですよ。

他の言語で同じことを書いたら行数が増えます。
例えばsed
2020/03/23(月) 16:50:24.71ID:OwPrjqjt
>>991
仲裁に入っただけの俺にそんな返しされても困る
2020/03/23(月) 17:22:17.80ID:gNyotYW5
>>982
予め断っておくが,
俺自身は「シェルスクリプトは万能」だなんて思ってない。
でも,プログラミング言語においてどういうものを「型」といって
どういうものを「型」と言わないのかを知りたい。
少なくともBashのdeclare組み込みコマンドには型機能が備わってるように見えるんだけど……
https://www.gnu.org/software/bash/manual/html_node/Bash-Builtins.html#index-declare
例えば「整数」として取り扱う場合には算術演算が記述できる,空だけど配列変数として指定できる,
みたいな機能って,「型」って言わないの?
994デフォルトの名無しさん
垢版 |
2020/03/24(火) 01:28:15.59ID:dWYBHKWQ
>>947
それ、スペースの入り方によってはうまくいかんよね。
やっぱ普通にダブルクォーテーションで括った方が良いのでは?
995デフォルトの名無しさん
垢版 |
2020/03/24(火) 22:04:54.75ID:/ZNMWK8v
シェルスクリプトで完結することはシェルスクリプトでやったほうがいいと思うわ。
プログラミング言語みたいにいちいち環境を構築しなくていいからね。
2020/03/25(水) 08:34:13.83ID:OJUUwfHr
>>991
sed楽だなー
改行も当然消せるよな、あれ、なんか面倒くせーぞ
そういう時はtr使うのか、なーんだよ
みたいな事がよくある
2020/03/25(水) 09:05:46.32ID:CcGCNzeN
>>995
人によって"シェルスクリプトで完結する"感覚が違うのが問題の始まり
2020/03/25(水) 09:59:10.25ID:C+CVbv8A
>>997
シェルスクリプトでコードが大きくなったら別言語でやる
というのは、単にシェルスクリプトをちゃんと勉強してないからだと思う

もともとシェルスクリプトでは実装が難しい問題であれば
最初からシェルスクリプトは使わない。例えばバイナリファイルとして
特定の位置のデータを読み書きするとか

でも最初にシェルスクリプトでやろうと思った時は、
シェルスクリプトでやるのが適した問題だったのだろう。
その後、やっぱり他の言語で〜って言い出す時は、
シェルスクリプトで作る能力がないことの言い訳だと思う
2020/03/25(水) 10:11:05.97ID:Y57VqPvD
読めてないのに参加するなよ
2020/03/25(水) 10:25:14.61ID:C+CVbv8A
>>999
おまえには理解できんだけさ
10011001
垢版 |
Over 1000Thread
このスレッドは1000を超えました。
新しいスレッドを立ててください。
life time: 152日 10時間 16分 29秒
レス数が1000を超えています。これ以上書き込みはできません。
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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