シェルスクリプト総合 その26 [無断転載禁止]©2ch.net

レス数が900を超えています。1000を超えると表示できなくなるよ。
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/
2018/04/03(火) 19:03:30.37
sedでlispを作った人はいる
2018/04/03(火) 19:33:57.64
どうかしてるぜ
2018/04/03(火) 22:20:55.54
>>842
使うことないだろうけど感動した
2018/04/03(火) 23:45:32.30
そんなことより野球やろうぜ
2018/04/04(水) 07:05:11.03
>>845
> sedって計算完備なんだっけ。
http://www.catonmat.net/blog/proof-that-sed-is-turing-complete/
2018/04/05(木) 00:02:39.79
家具家電彼女完備の家に住みたい
2018/04/05(木) 02:42:14.79
sinyabin.shの中でradiru.shを実行しています。
sinyabin.shの中の変数をradiru.shに引き継ぎたいんですが、どう書けばいいんでしょうか?
853852
垢版 |
2018/04/05(木) 03:31:27.11
radiru.shには、
pushbulettに録音開始の通知
ffmpegを使ってaacのダウンロード
l-smashを使ってaacをm4aに詰め替え
aacの削除
dropboxへm4aのアップロード
ローカルのm4aの削除
pushbulettに録音終了の通知をするコマンドを記入

radiru.shは
$ sinyabin.sh チャンネル 録音時間 ファイル名
で録音出来るようになっているので、

録画したい番組毎にsinyabin.sh等を作りその中に、
$ sinyabin.sh チャンネル 録音時間 ファイル名
を記入しています。

radiru.shの中のl-smashでaacをm4aにする際に番組名やアーティスト名などのタグ付けも一緒にやりたいので、sinyabin.sh側であらかじめl-smashで指定するタグのオプションを記入出来ればと思いました。
854852
垢版 |
2018/04/05(木) 03:41:17.05
radiru.shはaacのダウンロードだけにして、
Pushbulettへの通知、l-smash、Dropboxなどはsinyabin.shの方に書いたほうがいいんでしょうか?
そうすれば、ちょっと録音したいと思ったときいちいち番組毎のスクリプトをつくりその中にIDタグなど細かく書かなくてもすむから楽かなと。
でもそれだと、番組毎のスクリプトに「Pushbulettへの通知、l-smash、Dropbox」といったコマンドを書かないといけないので無駄かなあとも思いました。
どういうフローがいいと思いますか?
2018/04/05(木) 10:10:37.31
export すりゃいいんじゃない
2018/04/05(木) 10:22:06.60
こう質問の仕方が下手だと答える気失せるな
変数外に出せばいいだけ
2018/04/05(木) 10:59:32.39
852だけで良かったのにね
2018/04/05(木) 13:53:42.01
プログラミング素人っぽいし、加減がわかってないだろうから、
情報が多すぎる方は不問にした方が。
足りないよりは多すぎる方がずっとマシ。
2018/04/05(木) 18:12:51.21
>>853
radiru.sh に引数でタグ情報を渡せばいいと思いますが。
860名無しさん@お腹いっぱい。
垢版 |
2018/04/12(木) 09:36:41.69
bashだと$LINENOでファイルの中での現在の行数が取得できるのですが、
dashやzshだと関数の中にいる時、関数のはじめからの行数になってしまいます。
どうにかして現在の行数を取得する方法はないでしょうか?
2018/04/13(金) 19:02:57.86
zshよくしらんけど、関数定義の手前の行番号を
変数にでも取っといて足し算すりゃいいんじゃね?
2018/04/13(金) 19:07:33.88
まぁやりようは如何様にでもあるんだろうが、
ニュアンス的に$LINENO並の手軽さで取得する手段はないかってことじゃね
俺は知らん
2018/04/13(金) 22:14:56.99
$LINENOってどういう使い方を想定して作ったんだろうね
2018/04/13(金) 22:51:23.99
どこを見ればPOSIXシェルスクリプトの確かな仕様に出会えるのか知らないけど、
ググって出てきたこれにはLINENO書いてあるな。
User Portability Utilities optionが必要みたいだけど、なにそれ?
http://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html
2018/04/13(金) 23:40:07.60
実装オプションにつけてあるIDコードの一つみたいだな。
コードの一覧は
ttp://pubs.opengroup.org/onlinepubs/9699919799/help/codes.html
にある。

オプション機能なので、実装されてるとは限らない。
2018/04/14(土) 00:40:09.23
LINENOが仕様どおりに実装されてないのは
この際見なかったことにして、現在使われてる
POSIX準拠シェルで完全に実装されてないものなんて有るの?

そもそも現在使われてるPOSIX準拠シェルってどんなのがあるんだろう
bash、ash、dash、zsh、ksh、mksh、yash、posh
他に知ってる?
2018/04/14(土) 16:31:32.55
$LINENO使って何をしたいんだろ
2018/04/14(土) 19:01:06.26
デバッグログ以外になにかあんの?
だからこそデバッグログとして使えない
$LINENOを何のために作ったのか理解できない
2018/04/14(土) 19:14:03.26
${(%):-%I}
2018/04/14(土) 20:10:19.92
$ ${(%):-%I}
-bash: ${(%):-%I}: 誤った代入です
2018/04/17(火) 22:14:01.26
https://ja.wikipedia.org/wiki/IOCCC

> ^ Bourne Shellのソースコード( http://minnie.tuhs.org/cgi-bin/utree.pl?file=V7/usr/src/cmd/sh )は
> マクロ( http://minnie.tuhs.org/cgi-bin/utree.pl?file=V7/usr/src/cmd/sh/mac.h )を使用した
> 「ALGOLのような見た目のC」で書かれていることで悪名高い
872名無しさん@お腹いっぱい。
垢版 |
2018/04/18(水) 10:39:06.43
自己解凍するファイルって便利だな
シェルスクリプトで解凍とインストール手順を記述して
それをバイナリと結合するだけでmsiみたいなことができる
2018/04/18(水) 15:04:27.31
>>872
それはちなみに sh アーカイブ形式って呼び名がついてる。
sharっていう自己解凍シェルスクリプト作成専用コマンドも昔はあった。

なお、ウイルスやマルウェアの温床だということで廃れた模様。
2018/04/18(水) 15:22:26.44
sharはそれでインストールまでするというより、tar.gz などのバイナリファイルを
テキストにしてメールやニュースで送るために使うことが多かった
2018/04/18(水) 16:21:07.45
>>874
へー、uuencodeしか知らんかった
876872
垢版 |
2018/04/18(水) 21:50:42.61
あーわりと昔からある手法なのね……
VMware Horizon Clientのインストールイメージがその形で,俺は正直そういうシェルスクリプトとバイナリが結合されてるファイルを始めて触ったんで
画期的なアイデアに思えたんだわ……
2018/04/18(水) 23:47:33.56
echo "1 + 2" | bc > /tmp/a
とすると/tmp/aには2バイト、16進数で
33 0a のデータが入っています。

a=$(echo "1 + 2" | bc)
printf "$a" > /tmp/a
しかしこうすると$aには1バイトしか入ってないようです。

また [ "$(printf '1')" = "$(printf "1\n\n\n\n\n")" ]
これは一致した文字とみなされるようです

こういった挙動はどこを見れば理解できるでしょうか?
2018/04/18(水) 23:55:18.86
a="$(printf '1\n\n\n')"
とやってもaには1しか入っていない

a="$(printf '1\n\n\n2')"
しかしこうすると5バイト入ってる

その状態から a=${a%?} を末尾の2を削除すると
a には4バイト、1\n\n\n が入っている

うーん?
879名無しさん@お腹いっぱい。
垢版 |
2018/04/19(木) 00:06:08.07
>>877
コマンド置換 $(...) の仕様

http://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html#tag_18_06_03
> removing sequences of one or more <newline> characters at the end of
> the substitution. Embedded <newline> characters before the end of
> the output shall not be removed; however, they may be treated as
> field delimiters and eliminated during field splitting, depending on
> the value of IFS and quoting that is in effect. If the output
> contains any null bytes, the behavior is unspecified.

bashのマニュアルにも同様の記述がある

http://linuxjm.osdn.jp/html/GNU_bash/man1/bash.1.html#lbBC
> bash は command を実行し、 command の標準出力でコマンド置換の部分を
> 置き換えます。この際、末尾の改行文字は削除されます。 文字列の途中に
> ある改行文字は削除されませんが、 単語分割の際に削除されることがあり
> ます。
2018/04/19(木) 00:06:21.64
かといってこうやると4バイトでてるんだよなー

printf '1\n\n\n' | hexdump.exe -C
2018/04/19(木) 00:19:37.42
コマンド置換の仕様かぁ

普通のやり方ではコマンドの出力結果を変数に入れるときは
末尾の改行は絶対消えるってことかなー
read使えばって思ったけど、あっちは改行区切りだしなー

ちなみに $aに1\n\n\nを無理やり入れて、
$bに1を入れて [ "$a" = "$b" ] で比較したら不一致になったよ
2018/04/19(木) 00:24:31.94
あたりまえやろw
2018/04/19(木) 00:54:10.53
よくこんな単純なルールで辻褄取れてるよなー
思いつきで考えたとしか思えないルールなのにw
2018/04/24(火) 02:26:08.83
単純なルールのほうが整合性は取りやすいんでは? 寧ろ複雑な規則だと実装に矛盾が生じたりしそう。
885名無しさん@お腹いっぱい。
垢版 |
2018/04/27(金) 23:17:19.66
ちょっと質問
偶数日と奇数日で処理を分けたいんだけど、上手くできない
どうしたら良いのかアドバイスください

#!/bin/sh
DATE=`date '+%d'` # 日 を取得
buf=$(( $DATE % 2 )) # 計算

if [ ! $buf ]; then # 偶数
 hoge
else # 奇数
 fuga
fi
2018/04/27(金) 23:43:49.55
その計算するとこ()の中に$いるっけ
2018/04/28(土) 00:55:01.80
>>885
#! /bin/sh -

DATE="$(date "+%d")"

if [ $((DATE % 2)) -eq 0 ]; then
echo "今日は偶数Day"
else
echo "今日は奇数Day"
fi

ある種の言語(Cとかだっけ?)はif文に0を放り込めるけど、
コマンドを逐次実行するだけのシェルスクリプトでは無理。
面倒だけど数値判定をしなきゃいけない。
あと、>>886氏の言う通り演算置換内の変数に弗記号は不要。
あと、コマンド置換は容易く入れ子にできて対も分かりよい$()を使おう。
POSIX sh 2003でもサポートされているので安心して。
2018/04/28(土) 01:37:16.44
BSDで標準コマンドだけで現在時刻(もしくは起動してからの)ミリ秒ってとれないのな
/proc/uptimeもBSDないみたいだしどうにかして取れないかなー

ファイルに書き込んでタイムスタンプで
取れないかなーとかもやってみたりもしたw
ファイルシステムによっては書き込まれるみたいだが
これも標準コマンドだけでどうやればー

できればなにも入ってない素のコマンドだけでやりたいんだよね
Perlでもやれるけど、dateコマンドに比べたら
起動時間が10倍も違うんだよな。

あ、ベンチマークというかコマンドの実行速度を細かく知りたいために使いたい。
timeコマンドは標準出力(エラーだっけ?)を乱すので使いたくない
2018/04/28(土) 01:49:17.29
あれとれなかったっけ?
なんか取れた気がしたけど気のせいだったか
890名無しさん@お腹いっぱい。
垢版 |
2018/04/28(土) 19:41:21.09
>886-887
ありがとうできたよ。bufが空白になって常にelseに倒れてたから助かりました。
$の位置が良くわからなくて困っていたんだ

Cならいくらでも書けるんだけど、慣れない言語はちょとね・・・
2018/04/28(土) 20:34:44.86
>>888
timeコマンドの出力は標準エラーだよ。
標準出力の方は乱さない。

標準エラーが乱れる方も
(time sh -c '測りたいコマンド 2>&3' 2>/tmp/time.out ) 3>&2
みたいにすれば回避できるから、素直に time コマンド使う方がいい。
2018/04/28(土) 23:27:39.64
>>891
もう一つ問題があってなぁ。
dashじゃtimeコマンドビルトインじゃないんだよ
ビルトインじゃないからシェル関数で使えないんだよね
2018/04/29(日) 00:02:10.75
まあ使えないわけじゃないし候補にはなるけど、
OSごとに処理分けるの嫌だなぁ
2018/04/29(日) 00:07:48.59
/bin/timeって明示すれば?
2018/04/29(日) 02:10:30.87
もしくは
command -p time
2018/04/29(日) 08:34:10.39
いや、だからtimeコマンドだと
シェル関数扱えないからだめだって言ってるやん?
2018/04/29(日) 11:24:09.19
放置で
2018/04/29(日) 18:50:59.66
どうぞ
2018/04/30(月) 09:52:20.53
mkfifo便利すぎる
900名無しさん@お腹いっぱい。
垢版 |
2018/04/30(月) 10:17:56.64
シェルスクリプトの入門書を教えてください
ソフトバンクから出てるUNIXシェルスクリプト〜みたいな書名のものがAmazonでは評価高いみたいなんですが…
先輩方のおすすめを教えてください
901名無しさん@お腹いっぱい。
垢版 |
2018/04/30(月) 14:27:06.11
>>900
こういう分野に関してはいまだにオライリーは信頼できる書籍を発行してるぜ。
まあ俺の持論だがw

https://www.oreilly.co.jp/books/4873112672/
↑これとか参考になる。コマンドの列挙だけじゃなく、システムとシェルの性質とか非常に基礎的な部分から触れてるのでよい(と思う)。
902900
垢版 |
2018/04/30(月) 16:27:23.98
>>901
>システムとシェルの性質とか

これ正に知りたいことです
連休中本屋さん行くので是非中身読んで検討します
ありがとうございます
2018/05/02(水) 16:02:31.91
コマンドの出力結果を一時ファイルを作らずに
一行一変数に入れたいんですけどいい方法はないでしょうか?

変数はLINE1、LINE2・・・みたいな名前で
bash依存になる配列は使わない方針です。

foo | while read -r line; do
 LINE1=$line
done

みたいにするとサブシェルだから
ループ終わると消えてしまうし
2018/05/02(水) 16:34:46.41
sedかawkで代入文いっぱい出してevalかな。
特殊文字のエスケープちゃんと書かないといけないけど。
2018/05/02(水) 16:42:46.69
cat <<. |
1st Line
2nd Line
3rd Line
.
while read -r lineval; do
ctlino=$((ctlino + 1))
printf '%s%s' 'LINE'"${ctlino}"'='"$(printf '%s' "'")""${lineval}""$(printf '%s' "'")" ';'
done |
printf '%s%s\n' "$(cat)" ':'
とりあえずこうすると
LINE1='1st Line';LINE2='2nd Line';LINE3='3rd Line';:
という出力が得られる。これを評価すればいいと思ったができねえ。
2018/05/02(水) 16:59:04.80
改良?
cat <<'EOF' |
1st Line
2nd Li'ne
3rd Line
EOF
while read -r lineval; do
ctlino=$((ctlino + 1))
printf '%s' "${lineval}" |
sed 's/'"'"'/'"'"'"&"'"'"'/g' |
printf '%s%s' 'LINE'"${ctlino}"'='"'""$(cat)""'" '; '
done
→ LINE1='1st Line'; LINE2='2nd Li'"'"'ne'; LINE3='3rd Line'; :
2018/05/02(水) 17:00:08.10
改良?
cat <<'EOF' |
1st Line
2nd Li'ne
3rd Line
EOF
while read -r lineval; do
ctlino=$((ctlino + 1))
printf '%s' "${lineval}" |
sed 's/'"'"'/'"'"'"&"'"'"'/g' |
printf '%s%s' 'LINE'"${ctlino}"'='"'""$(cat)""'" '; '
done |
printf '%s%s\n' "$(cat)" ':'
とりあえず単引用符のエスケープだけ。他にも必要なものがあればsedを挟んでいけばいいんでは。
2018/05/02(水) 17:12:01.86
> sedかawkで代入文いっぱい出してevalかな。
やっぱり残る手はそれか
2018/05/02(水) 17:18:49.70
$ radico rec -id=FMT -s=20180502040000
というコマンドがあったとして、「-s=」あとに今日の朝4時「date +"%Y%m%d"040000」の結果を入れたいんですが、一行で書く方法を教えてください
2018/05/02(水) 17:28:29.77
お前はこの前のレス群に対する結果とか報告してからにしろ
2018/05/02(水) 18:12:16.93
何も考えずぶん投げるけど変数exportとかじゃだめなのか
2018/05/02(水) 18:28:09.05
出来ました!
2018/05/02(水) 19:53:51.97
>>909
$ radico rec -id=FMT -s=$(date "+%Y%m%d040000")
コマンド置換くらい自力で調べーや
2018/05/02(水) 21:09:33.58
引数 $1 $2 $3 ・・・ のうち、特定の範囲n〜mを
別の関数の引数に渡すのってどうやればいいだろうか?
n〜mは条件で変わるものとする
2018/05/02(水) 21:27:56.41
>>914
一兆個のシェルを書いてきた俺がそんな事必要になった事がないから
お前の解こうとしてる問題が間違っている
2018/05/02(水) 21:34:19.62
>>915
やってることが簡単なパーサーのようなものですからね。
exprをシェルスクリプトで実装しているようなものです。
流石にこういう高度なことはやったことがないのでは?
2018/05/02(水) 22:27:50.67
shift $argnum
とかは?
2018/05/02(水) 22:47:14.90
>>917
それだと前からn個以降は実現可能だけど
範囲ができないんですよね。
2018/05/02(水) 22:51:49.30
bashだとこんな感じですね

foo() { echo "${@:2:3}"; }

$ foo 1 2 3 4 5
2 3 4
2018/05/03(木) 00:40:42.42
>>918
for文使えば?
selectargnum()
{
fromargnum=$1
toargnum=$2
shift ${fromargnum}
for arg in $(seq $((toargnum - fromargnum + 1))); do
printf '%s\n' "$2" && shift
done
}

selectargnum 3 5 "$@"

注意: シェル函数への第1,2引数は必ず非負整数で,引数の範囲内であるべし。
2018/05/03(木) 00:47:51.26
#! /bin/sh -

selectargnum()
{
fromargnum=$1
toargnum=$2
shift ${fromargnum}
for arg in $(seq $((toargnum - fromargnum + 1))); do
printf '%s\n' "$2"
shift
done
}

selectargnum 2 4 "$@"

もうちょっと親切に書くわ。

シェル函数selectargnumの
::仕様::
selectargnum <開始位置> <終了位置> <(処理したい)引数>
開始位置・終了位置は省略不可で,常識的な範囲であることを前提にしている。
::使い方::
上のコードを適当な名前のファイル(例えばselarg.sh)に保存して実行権限を賦与。
$ chmod +x ./selarg.sh
あとはファイル中のselectargnum函数の第1,2引数を書き換えて使える。
上の例なら
$ ./selarg.sh "第1引数" "第2引数" "第3引数" "第4引数" "第5引数"
に対して
第2引数
第3引数
第4引数
という出力が得られる。
2018/05/03(木) 00:50:36.20
seqを除いてPOSIX準拠。
もしもより厳密にPOSIXに従いたければ当該箇所を
seq $((toargnum - fromargnum + 1))
から
yes | head -n $((toargnum - fromargnum + 1))
としてもいいだろう。
2018/05/03(木) 03:17:05.15
>>919のせいで勘違いさせたようですね

> 別の関数の引数に渡すのってどうやればいいだろうか?
重要なのはこれ

another_function() {
for i in "$@"; do
printf "%s\n" "$i"
done
}

foo() { another_function "${@:2:3}"; }

another_functionはそのまま使って、
fooの部分をPOSIX準拠にして
以下のような出力を得たいということです

$ foo a "b 1" "c 1" d e
b 1
c 1
d
2018/05/03(木) 03:18:03.35
eval使うしか無いっすかね?
2018/05/03(木) 03:20:16.97
このコードの応用でできますかね?
いまいちこのコードがなにやってるのかよくわからんのですが

https://unix.stackexchange.com/questions/258512/how-to-remove-a-positional-parameter-from

for arg do
shift
[ "$arg" = "-inf" ] && continue
set -- "$@" "$arg"
done

printf '%s\n' "$@"
2018/05/03(木) 03:42:12.53
>>923
おいおいヒドいな俺の>>920-922は無視かよ
引数をどうにかしたいコマンドをsomefuncとして
#! /bin/sh -

selectargnum()
{
fromargnum=$1
toargnum=$2
shift ${fromargnum}
for arg in $(yes | head -n $((toargnum - fromargnum + 1))); do
printf '%s\n' "$2"
shift
done
}

somefunc()
{
printf '%s\t%s\n%s\n' "$2" "$3" "$1"
}

somefunc $(selectargnum 2 4 "$@")

こういうので実現できると思うんだが?
なにかこれでは駄目な点があれば言ってくれ。
せっかくGW中とは言え頭使ったのにあまりにもあまりな仕打ちじゃマイカ
2018/05/03(木) 04:08:41.64
>>926
somefuncは分かりづらいんでこう書き換えるけど
somefunc() {
printf '%s\n' "$@"
}

$ test.sh "a" "b" "c" "d" "e"
b
c
d

こうなるところ
$ test.sh "a 1" "b 1" "c 1" "d 1" "e 1"
b
1
c
1
d
1
2018/05/03(木) 04:23:08.37
somefuncはこうしないとだめだな。
何番目の変数に入っているのか分かりづらい

somefunc() {
printf '1: %s\n' "$1"
printf '2: %s\n' "$2"
printf '3: %s\n' "$3"
}
2018/05/03(木) 04:23:43.87
なんかすごいどうでもいいことしてる気にならん?
2018/05/03(木) 04:26:07.99
しょうがないだろう。
引数には空白、シングルクォート、ダブルクォート、改行が
含まれる可能性があるんだよ
2018/05/03(木) 04:29:26.87
一見うまくいったと思いきや
$ test.sh "a" "b" "c" "d" "e"
1: b
2: c
3: d

変数Aに改行が含まれている文字列を入れ
$ A="b
b
b
b
"

以下のように実行するとおかしくなる
$ test.sh "a" "b${A}b" "c" "d" "e"
1: bb
2: b
3: b

> なにかこれでは駄目な点があれば言ってくれ。

駄目な点を言った
2018/05/03(木) 04:32:29.46
なお、俺が書いたコードだと以下のように正しく出力される

$ test.sh "a" "b${A}b" "c" "d" "e"
1: bb
b
b
b
b
2: c
3: d

>>925を参考にして以下のように書いた

selectargnum() {
func=$1 start=$2 length=$3
shift 3
i=0 last=$((start+length))
for arg in "$@"; do
: $((i+=1))
[ $i -gt $length ] && shift
[ $i -ge $last ] && continue
shift
set -- "$@" "$arg"
done
$func "$@"
}
somefunc() {
printf '1: %s\n' "$1"
printf '2: %s\n' "$2"
printf '3: %s\n' "$3"
}
selectargnum somefunc 2 3 "$@"
2018/05/03(木) 04:34:38.30
ただ問題は、>>932のコードを書いた俺自身が
なんでこのコードで動くのかよく分かってない所だなw
誰か俺の書いたコードが何をやってるのか教えてくれw

>>925のコードはなにやら引数を一周させているみたいだ。
俺が書いたコードは、その一周を途中で中断させているようだな?
2018/05/03(木) 04:37:45.65
eval使ったほうが簡潔かつ速い気がしてきたw
set -- の所、何度も引数をずらす処理をしているわけだしね。
2018/05/03(木) 04:38:19.15
長い
読む気にならん
2018/05/03(木) 04:39:32.30
長くて読まないのはわかるが、
なぜ読まないということをわざわざ宣言するんだろう?
2018/05/03(木) 04:42:04.26
まあ長いのは、>>926のコードに合わせたからであって、
メインの処理はこれだけなんだけどね

i=0 start=2 length=3 last=$((start+length))
for arg in "$@"; do
 : $((i+=1))
 [ $i -gt $length ] && shift
 [ $i -ge $last ] && continue
 shift
 set -- "$@" "$arg"
done

printf '1: %s\n' "$1"
printf '2: %s\n' "$2"
printf '3: %s\n' "$3"
2018/05/03(木) 05:49:25.62
>>932
ちょっとリファクタリング(ってほど大層じゃないが)
selectargnum() {
 func="$1"; start=$2; length=$3
 shift 3
 i=0; last=$((start + length))
 for arg in "$@"; do
  i=$((i + 1))
  test ${i} -gt ${length} && shift
  test ${i} -ge ${last} && continue
  shift
  set -- "$@" "${arg}"
 done
 "${func}" "${@}"
}
2018/05/03(木) 06:31:02.21
>>938
文字増やしてるだけじゃねーかw
2018/05/03(木) 06:31:17.96
不要な文字
2018/05/03(木) 06:50:55.78
リファクタリングは文字数減らすことを言うのじゃないけど
2018/05/03(木) 07:41:52.01
不必要な機能
2018/05/03(木) 09:41:05.71
一旦SQLiteにでも格納すれば何でも出来るで
2018/05/03(木) 12:57:05.87
なんか余計に読みづらくなっただけのような
945名無しさん@お腹いっぱい。
垢版 |
2018/05/03(木) 13:11:25.55
解こうとしてる問題が間違っていると言ったやろw
2018/05/03(木) 13:13:23.38
bashだと簡単にできるようになったことのどこが
間違っているというのだろうか?
レス数が900を超えています。1000を超えると表示できなくなるよ。
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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