シェルスクリプト総合 その24©5ch.net
■ このスレッドは過去ログ倉庫に格納されています
0001名無しさん@お腹いっぱい。 転載ダメ©2ch.net
2014/11/11(火) 00:54:03.43□お約束
・特記なき場合は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.opensolaris.org/source/xref/onnv/onnv-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に逃げずにシェルスクリプトで処理するのが頭のいいやり方。
前スレ
シェルスクリプト総合 その23
http://peace.2ch.net/test/read.cgi/unix/1404204950/
0660名無しさん@お腹いっぱい。
2015/05/25(月) 21:12:27.930661659
2015/05/25(月) 21:36:30.45教本に応えが載ってなくて、序盤のページで行き詰ってしまいました。
0662名無しさん@お腹いっぱい。
2015/05/25(月) 21:46:27.07total=0
r=0
until test $#@ -eq 0
do
case $(( r % 4 == 0 ? 1 : (r + 3) % 4 == 0 ? 2 : (r + 2) % 2 == 0 ? 3 : 4 )) in
1) total=$(( total + $1 ));;
2) total=$(( total - $1 ));;
3) total=$(( total * $1 ));;
4) total=$(( total / $1 ));;
esac
shift
(( ++r ))
done
0663名無しさん@お腹いっぱい。
2015/05/25(月) 21:53:31.12r=0
until test $# -eq 0
do
case $(( r % 4 == 0 ? 1 : (r + 3) % 4 == 0 ? 2 : (r + 2) % 2 == 0 ? 3 : 4 )) in
1) total=$(( total + $1 ));;
2) total=$(( total - $1 ));;
3) total=$(( total * $1 ));;
4) total=$(( total / $1 ));;
esac
shift
(( ++r ))
done
0664名無しさん@お腹いっぱい。
2015/05/25(月) 21:55:32.99for a b c in 1 2 3
do
echo $a $b $c
done
みたいな処理もできる。
0665名無しさん@お腹いっぱい。
2015/05/25(月) 22:08:26.160666名無しさん@お腹いっぱい。
2015/05/25(月) 22:21:07.68baseの後に何が書いてあるのか分らない時は
三項演算子というのを調べると良い。
0667名無しさん@お腹いっぱい。
2015/05/25(月) 22:21:52.930668名無しさん@お腹いっぱい。
2015/05/25(月) 22:37:26.67echo "total = $total"
0669名無しさん@お腹いっぱい。
2015/05/25(月) 23:22:22.44どれだけ偉いんだって話だよな。
0670名無しさん@お腹いっぱい。
2015/05/26(火) 01:08:45.37まあawkでいいような気もするけど。
0671659
2015/05/26(火) 06:28:38.160672名無しさん@お腹いっぱい。
2015/05/26(火) 14:02:41.07PROMPT_COMMANDの設定について教えて下さい。
ターミナルのタイトルバーに現在のディレクトリ名"だけ"を表示したいのですが、
プロンプトの設定でやる
PS1=\w
のような \w がPROMPT_COMMANDの設定では使えないんですね?
どうやったらいいのでしょうか?
0673名無しさん@お腹いっぱい。
2015/05/26(火) 15:34:18.870674名無しさん@お腹いっぱい。
2015/05/26(火) 15:43:42.530675名無しさん@お腹いっぱい。
2015/05/26(火) 15:53:38.10PROMPT_COMMAND='echo -ne "\033]0;${USER}@${HOSTNAME}: ${PWD/$HOME/~}\007"'
PROMPT_COMMAND='echo -ne "\033]0;${PWD/$HOME/~}\007"'
0676名無しさん@お腹いっぱい。
2015/05/26(火) 20:32:22.47ごめん。三項演算子に間違いがあった。
(r + 2) % 2 == 0 ? 3 : 4 )) in じゃなくて
(r + 2) % 4 == 0 ? 3 : 4 )) in だった。
以下楽しくなって、もう一つ書いといた。zshでしか動かないけれど。
a=(+ - \* /)
b ()
{
(( $# == 1 )) || b $@[1,-2]
total=$(( total $a[$(( ($# + 3) % 4 == 0 ? 1 : ($# + 2) % 4 == 0 ? 2 : ($# + 1) % 4 == 0 ? 3 : 4 ))] $@[-1] ))
echo $total
}
b $@
じゃあ勉強頑張って。
0677659
2015/05/26(火) 21:00:09.14sh、zsh、bashの違いが何やら…
0678名無しさん@お腹いっぱい。
2015/05/26(火) 22:22:51.71そんなあなたにbusybox
0679名無しさん@お腹いっぱい。
2015/05/27(水) 08:32:10.49と思う。だからbashとzshは配列の扱いなど雑多な違いがある。以下昨日のbash版。
たぶんもっと簡素に書けるのだろうけど私も全然詳しくない。
a=(+ - \* /)
b ()
{
declare -a c=( $@ )
(( $# == 1 )) || b $( echo ${c[@]} |cut -d ' ' -f -$(( $# - 1 )) )
total=$(( total ${a[$(( ($# + 3) % 4 == 0 ? 0 : ($# + 2) % 4 == 0 ? 1 : ($# + 1) % 4 == 0 ? 2 : 3 ))]} ${c[$# - 1]} ))
echo $total
}
b $@
以下みたいな書き方も簡易な条件文。何が起こるのかは(( 1 ))した後にecho $?とかして
値を確認できる。c言語は0が偽だけどshellだと0が真なので注意。cでreturnで0返すでしょ。
さらに(( 0 ))などは、echo $?した時に0として返っていない事に注目。
(( 1 )) && echo true
(( 0 )) || echo true
自ら自らを呼ぶ、再帰関数は調べればすぐ出てくる。
declareは、再帰関数ゆえ、変数名が同じになってしまうから、関数を呼んだ側の変数の値を、
呼ばれた側が変える事が無いようにしている。ローカル変数とか、スコープとか調べると出てくる。
0680名無しさん@お腹いっぱい。
2015/05/27(水) 10:46:37.27コマンドライン引数で指定されたキーワードに一致する部分を持つ、カレントディレクトリ配下のファイルをそのディレクトリ階層をそのままにコピーしたいのですが、何かよい方法はありますでしょうか。
何かよい方法はありますでしょうか。
実行環境はCentOSをTera Term とSSH接続している状態です。
実行例として
[user@portal ~]$ ./sample.sh A copyTo
第1引数はキーワード、第2引数はコピー先のディレクトリ
これでコピーができたことをTera Term上で確認できることが望ましいです。
0681名無しさん@お腹いっぱい。
2015/05/27(水) 11:05:38.310682名無しさん@お腹いっぱい。
2015/05/27(水) 13:08:06.76#!/bin/sh
find . -name "*$1*" | cpio -oc | (cd "$2" && cpio -ivdc)
0683名無しさん@お腹いっぱい。
2015/05/27(水) 13:41:16.73#!/bin/sh
cp -Rv ["$1"] "$2"
>>682はビット演算子使っててよくわからないですが、目的の動作は確認致しました!
ありがとうございます!
0684名無しさん@お腹いっぱい。
2015/05/27(水) 16:04:06.520685名無しさん@お腹いっぱい。
2015/05/28(木) 10:32:09.00第1 + 第2 - 第3 * 第4 / 第5 + 第6 - …
って処理が正しい
0686名無しさん@お腹いっぱい。
2015/05/28(木) 12:07:05.77total=$1; shift
a=(+ - \* /)
b ()
{
(( $# == 1 )) || b $@[1,-2]
total=$(( total $a[$(( ($# + 3) % 4 == 0 ? 1 : ($# + 2) % 4 == 0 ? 2 : ($# + 1) % 4 == 0 ? 3 : 4 ))] $@[-1] ))
echo $total
}
b $@
0687名無しさん@お腹いっぱい。
2015/05/28(木) 12:23:47.19まぁ本人じゃないだろうし引かせてもらおう。
0688名無しさん@お腹いっぱい。
2015/05/28(木) 12:25:16.28total=$1; shift
だけでいいんじゃないかな。急ぎなので、確認して無いけど。
0689名無しさん@お腹いっぱい。
2015/05/28(木) 12:32:06.050690名無しさん@お腹いっぱい。
2015/05/28(木) 12:32:46.85自分も、参考までに考えておいた
初期値は 0、引数の数は不定で、加算、減算、乗算、除算を繰り返すと解釈した
#! /bin/sh -x
while
total=$(
echo "( ${total:-0} ${1:++ $1} ${2:+- $2} ) ${3:+* $3} ${4:+/ $4}" | bc
)
[ 4 -lt $# ] && shift 4
do :
done
echo "ANSWER: ${total}"
exit
#! /bin/sh -x
while [ 0 -lt $# ]
do
total=$(
echo "( ${total:-0} + ${1:- 0} - ${2:- 0} ) * ${3:- 1} / ${4:- 1}" | bc
)
shift $(( $# > 4 ? 4 : $# ))
done
echo "ANSWER: ${total:-0}"
exit
0691名無しさん@お腹いっぱい。
2015/05/28(木) 12:35:03.520692名無しさん@お腹いっぱい。
2015/05/28(木) 18:17:15.57# 以下をtest.shで保存。
#!/bin/sh
a='/+-*'
test $# -eq 1 && { echo $1; exit; } || total=$( ./test.sh $( echo $@ |cut -d ' ' -f -$(( $# - 1 )) ) )
echo $(( $total $( echo $a |cut -b $(( ( $# + 3 ) % 4 + 1 )) ) $( eval echo \$$#) ))
0693名無しさん@お腹いっぱい。
2015/05/28(木) 21:33:17.290694名無しさん@お腹いっぱい。
2015/05/28(木) 21:54:55.27# 割り算部分はできたよ。もう疲れたからやめようかな。
# scaleの値を調整すれば何処まで計算するか指定できる。
# -の値を指定するとずっと計算し続けるので注意。
# dashで動くように書いてる。
#!bin/sh
scale=8
total=$1; shift
m ()
{
test $(( $3 )) -eq 0 -o $(( $1 )) -eq 0 && return
b=$1
a=$(( ${b}0 / $2 ))
echo -n $a
m $(( ${b}0 % $2 )) $2 $(( $3 - 1 )) # 余り、割る数、scale.
}
echo -n $(( total / $1 )).
m $(( total % $1 )) $1 $scale
0695名無しさん@お腹いっぱい。
2015/05/28(木) 22:03:27.91./保存したfile 355 113
と引数二つです。
0696名無しさん@お腹いっぱい。
2015/05/29(金) 02:54:31.46>>690 本人じゃなくてわめいてる方ですけど、勉強になります。
一つ目書き方は知らないので勉強しておく事して二つ目ので見ると、
そっか、と思わされました。確かにその通りだと、コードも短いし理解もしやすいし。
>>659は彼のを参考にしたほうが良かと。私のは今考えて見ると三項演算子も無駄だったし、
ただ>>692は毒毒しい事をしているので、結構勉強になると思う。
0697名無しさん@お腹いっぱい。
2015/05/29(金) 13:11:54.28# ごめん>>694 それ再帰してるから途中で計算できてなかった。
# 悪い所も無駄に関数な所も直して無いけど。以下でいける。
scale=-1
total=$1; shift
m ()
{
b=$1 # $1: 余り、$2: 割る数、$3: scale.
until test $scale = 0 -o b = 0
do
a=$(( ${b}0 / $2 ))
echo -n $a
b=$(( ${b}0 % $2 ))
scale=$(( scale - 1 ))
done
}
echo -n $(( total / $1 )).
m $(( total % $1 )) $1 $scale
0698名無しさん@お腹いっぱい。
2015/05/29(金) 13:15:06.250699名無しさん@お腹いっぱい。
2015/05/29(金) 14:07:59.500700名無しさん@お腹いっぱい。
2015/05/29(金) 17:25:17.77while false
true
do
echo test
break
done
前にfor分は以下で動くのになんでwhileは駄目なんだろうと思った、謎がとけました。
for r in *
{
echo $r
}
0701名無しさん@お腹いっぱい。
2015/05/29(金) 17:41:57.11離れ隠しとも名付けようかこの新手
0702名無しさん@お腹いっぱい。
2015/05/29(金) 19:43:00.94> >>690 本人じゃなくてわめいてる方ですけど、勉強になります。
意外な効果で驚くなあ。でも、役に立って良かった
> 一つ目書き方は知らないので勉強しておく
って言葉で改めて見直すと
> 序盤のページで行き詰ってしまいました。
序盤で行き詰まっているんだよね。そんな人に対して適当な回答じゃあ無かったかもしれないなあ
( parameter substitution の機能とか使うべきではなかったか )と思い、妙なヒント入りでもう一度書いておきました
蛇足だけど、V7 Bourne Shell だと、:- でなく - なんだよね
http://www.in-ulm.de/~mascheck/bourne/v7/
> ${parameter-word}
> If parameter is set then substitute its value; otherwise substitute word.
それでなのか、POSIX でも定義されていて
http://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html#tag_18_06_02
bash や、dash でも echo ${HOGE-$HOME} が機能する
>>701
man dash, man bash, man ksh, man zshmisc と確認してみたけど
while list; do list; done 相当の事が書いてある
結構誰でも知っているて、新手では無いよ
0703名無しさん@お腹いっぱい。
2015/05/29(金) 19:44:12.32total=0
while
case $# in
0)
break
;;
1)
total=$( echo "${total} + $1" | bc )
break
;;
2)
total=$( echo "( ${total} + $1 - $2 )" | bc )
break
;;
3)
total=$( echo "( ${total} + $1 - $2 ) * $3" | bc )
break
;;
0704名無しさん@お腹いっぱい。
2015/05/29(金) 19:44:26.35total=$( echo "( ${total} + $1 - $2 ) * $3 / $4" | bc )
break
;;
[5-9]|[0-9]*[0-9])
total=$( echo "( ${total} + $1 - $2 ) * $3 / $4" | bc )
shift 4
true
;;
*)
echo 'It never comes here and we know it.' >&2
exit 1
;;
esac
do : 'Do nothing with list-2 of "while list-1; do list-2; done"'
done
echo "ANSWER: ${total}"
exit
0705名無しさん@お腹いっぱい。
2015/05/30(土) 04:04:02.38#!/bin/zsh
eval echo -n \${$#..1} \'$( yes '+-*/'|tr -d '\n' |dd bs=$(( $# - 1)) \
count=1 cbs=1 conv=unblock 2>/dev/null | sed 's#^#r#')\' p |dc
#!/bin/sh
{ eval echo -n $( seq -f "$%g" $# |tac ); echo "$( yes '+-*/'|tr -d '\n' \
|dd bs=$(( $# - 1)) count=1 cbs=1 conv=unblock 2>/dev/null | sed 's#^#r#' )" p; } |dc
0706名無しさん@お腹いっぱい。
2015/05/30(土) 07:57:05.78eval echo $( seq -f "$%g" $# | tac )
の部分は "$@" とか使えないものかと思い、しばらく考えたんだが...
echo "$@ " | tac -s " "
0707名無しさん@お腹いっぱい。
2015/05/31(日) 07:18:32.49#!/bin/sh
eval echo 0 $( printf '$%d + $%d - $%d @ $%d /' $( seq $# ) | \
sed 's#+ $0#+ 0#g; s#- $0#- 1#g; s#@ $0#@ 1#g; a p' ) |tr '@' '*' |dc
0708名無しさん@お腹いっぱい。
2015/05/31(日) 08:54:03.31後段も書き換えてみた
echo "$( yes '+-*/'|tr -d '\n' \
|dd bs=$(( $# - 1)) count=1 cbs=1 conv=unblock 2>/dev/null | sed 's#^#r#' )" p
#! /bin/sh
# 何をするスクリプトかぱっと見で全くわからないので、一応書いておくけど、
# これも >>659 の回答
{
echo "$@ " | tac -s " "
yes 'r+r-r*r/' | tr -d '\n' | head -c $(( ( $# - 1 ) * 2 ))
echo "p"
} | dc
>>707
アイデアが尽きないね。@は、エスケープ用かな?外しておいた
#! /bin/sh
eval echo 0 $(
printf '$%d + $%d - $%d \\* $%d / ' $( seq $# ) |
sed 's#+ $0#+ 0#g; s#- $0#- 1#g; s#* $0#* 1#g; a p'
) | dc
0709名無しさん@お腹いっぱい。
2015/05/31(日) 11:51:51.690710名無しさん@お腹いっぱい。
2015/05/31(日) 12:23:30.92eval とかなるべく使いたくないけど、printf で展開するアイデアが面白いな
#! /bin/sh
{
eval echo 0 $(
printf '$%d + $%d - $%d \\* $%d / ' $( seq $# ) |
sed -e 's/$0 [+/*\-]* //g'
)p
} | dc
0711名無しさん@お腹いっぱい。
2015/05/31(日) 18:16:33.13#! /bin/sh
{
echo 0 $(
n=$(( $# % 4 ))
printf '%d + %d - %d \\* %d / ' "$@" |
sed -e 's/\([0-9]\{1,\} [+/*\-]* \)\{'"$(( n == 0 ? 0 : 4 - n ))"'\}$//'
)p
} | dc
0712名無しさん@お腹いっぱい。
2015/06/01(月) 06:34:30.80訂正
#! /bin/sh
{
echo "0 $(
n=$(( $# % 4 ))
printf '%d + %d - %d * %d / ' "$@" |
sed -e 's/\([0-9]\{1,\} [+/*\-]* \)\{'"$(( n == 0 ? 0 : 4 - n ))"'\}$//'
)p"
} | dc
0713名無しさん@お腹いっぱい。
2015/06/02(火) 19:51:41.64#! /bin/sh
echo "0 $( printf '%s + %s - %s * %s / ' "$@" "END" | sed -e 's/END.*$//' )p" | dc
0714名無しさん@お腹いっぱい。
2015/06/02(火) 20:48:50.220715名無しさん@お腹いっぱい。
2015/06/04(木) 06:35:03.60printf '%s + %s - %s * %s / ' "$@" "END" | sed -e 's/^/0 /; s/END.*$/p/' | dc
0716名無しさん@お腹いっぱい。
2015/06/06(土) 17:40:55.66ここのpageを見て理解しながら作りました。
http://www.maitou.gr.jp/rsa/
素数判定のアルゴリズムは以下のC言語のものを、冪乗の計算を一度に変えたものです。
http://ja.wikipedia.org/wiki/%E7%B4%A0%E6%95%B0%E5%88%A4%E5%AE%9A
今は一度コメントを全部消した状態で貼っておきます。
dcで書いてるので呪文っぽいので理解しようとしないほうが吉です。
そのうちbase64でコメントつけて貼るかもしれません。
factorにすぐやられますから、実用性は無いです。
dashで動くつもりでしたがzshでなければ動きません。
printf %d 010
とした時の挙動の違いに今気付きました。
0717名無しさん@お腹いっぱい。
2015/06/06(土) 17:42:57.23# 例: prime 10000 20000
prime ()
{
dc -e "$( seq $1 ${2:-$1} )"'
z sc 0 sr [S2 lr 1 + sr lr lc >!] s! l! x
[[sg 3 Q] sk [p sg 3 Q] s.] sA
[d 2 >k d 2 =. d 2 % 0 =k] sB
[[sg 2 Q] sk [p sg 2 Q] s. d v s^ 3 s/] sC
[l^ l/ >. d l/ % 0 =k l/ 2 + s/ lD x] sD
0 sr
[L2 [lA x lB x lC x lD x]x lr 1 + sr lr lc >@] s@ l@ x
'
}
# 上記、prime関数から得られた適当な素数二つが引数です。
# そこから秘密鍵、公開鍵を出力します。
# 例: keygen 10243 19963
keygen ()
{
dc -e "[$1 1 :a]x [$2 2 :a]x [$1 $2 * 3 :a]x"'
[1 ;a]x 1 - [2 ;a]x 1 - * 2 / 1 + S2
[l2 lr [d la :k]x / [la :p]x la 1 + sa l. x] sA
[[la 1 - ;k]x n [ ] n [la 1 - ;p]x n [ ] n [3 ;a]x p sg] s.
1 sa l2 v s^ 2 sr
[l2 lr % 0 =A lr 1 + sr lr l^ !<B] sB lB x
'
}
0718名無しさん@お腹いっぱい。
2015/06/06(土) 17:44:29.67# 例:
# keygen 10243 19963
# > 7 14603629 204481009
# > 17 6013259 204481009
# > 119 859037 204481009
# encrypt 859037 204481009 暗号化するfile >暗号化した後のfile
encrypt ()
{
echo 8 o $( printf "8 i %d 12 i $1 $2 | n [ ] n " $( od -vt oC -A n $3 ) ) |dc
}
# 上記の公開鍵で暗号化したものを、秘密鍵で復号します。秘密鍵は上記の例で暗号化した場合、
# 以下の組み合わせになります。
# encrypt 119 204481009 暗号化されたfile >復号化した後のfile
decrypt ()
{
printf "8 i %d 12 i $1 $2 | P " $( cat $3 ) |dc
}
0719名無しさん@お腹いっぱい。
2015/06/06(土) 20:13:54.610720名無しさん@お腹いっぱい。
2015/06/06(土) 20:27:58.37# 他に、確認に使ったprogram.
# ずるしてopensslを使っています。
# まず!!!!!!!!復号化するfileに値を入れて下さい!!!!!!!!!!!!!。小さいfileが良いと思います。
# mktempで作るfileは自動では削除しません。最初にechoで出力するので手動でお願いします。
# primeで適当な素数を二つ選択しkeygenを行い、そこで作られた鍵で暗号化したfileを
# 復号できるかの確認です。
# 使い方。
# check_2 $( prime 10000 20000 )
# 出力は、出力した時に確認したkeygenに使った素数二つ,暗号化復号化に使える数字と法です。
0721名無しさん@お腹いっぱい。
2015/06/06(土) 20:29:33.71file_encrypt=$( mktemp )
file_decrypt=$( mktemp )
echo 後で削除する事、$file_encrypt $file_decrypt
check_2 ()
{
test $# -lt 2 && return
p1=$( echo $@ |tr ' ' '\n' |sed -n $(( $( openssl rand 2 \
|od -t u -A n ) % $# + 1 ))p )
while # 使いました!!!
p2=$( echo $@ |tr ' ' '\n' |sed -n $(( $( openssl rand 2 \
|od -t u -A n ) % $# + 1 ))p )
test $p2 -eq $p1
do :
done
f ()
{
test $# -eq 0 && return
encrypt $(( $# % 2 ? $1 : $2 )) $3 $file >$file_encrypt
decrypt $(( $# % 2 ? $2 : $1 )) $3 $file_encrypt >$file_decrypt
diff $file $file_decrypt && echo 成功。keygen $p1 $p2, $1 $2 $3 \
|| echo 失敗。keygen $p1 $p2, $1 $2 $3 1>&2
shift 3
f $@
}
f $( keygen $p1 $p2 )
check_2 $( echo $@ |tr ' ' '\n' |grep -vE "($p1|$p2)" )
}
# rm $file_encrypt $file_decrypt
0722名無しさん@お腹いっぱい。
2015/06/06(土) 20:36:41.36opensslのrandの値も変える必要があったような気がします。もう忘れました。
現在対したコメント無くてごめんなさい。
0723名無しさん@お腹いっぱい。
2015/06/07(日) 19:13:41.49printf '%s + %s - %s * %s / ' '0 0' 0 1 1 "$@" 'p quit' | dc
>>716-722 力作ですなぁ
072410人に1人はカルトか外国人
2015/06/08(月) 17:47:19.33・沢山の人が偏った意見を一貫して支持する
偏った意見でも、集団の中でその意見が信じられていれば、自分の考え方は間違っているのか、等と思わせる手法
・不利な質問をさせなくしたり、不利な質問には答えない、スルーする
誰にも質問や反論をさせないことにより、誰もが皆、疑いなど無いんだと信じ込ませる手法
偏った思想や考え方に染まっていたり、常識が通じない人間は、頭が悪いフリをしているカルト工作員の可能性が高い
靖国参拝、皇族、国旗国歌、神社神道を嫌うカルト
10人に一人はカルトか外国人
「ガスライティング」で検索を!
0725名無しさん@お腹いっぱい。
2015/06/08(月) 21:12:33.56find /foo -iname "123foo.txt" -o -iname "foo.txt"
をしたくて、"123foo.txt" から"foo.txt"を
作りたいのですけどいい方法を教えていただけないでしょうか?
123は0桁から4桁あります。
よろしくお願いします。
0726名無しさん@お腹いっぱい。
2015/06/08(月) 22:27:29.530727名無しさん@お腹いっぱい。
2015/06/08(月) 23:04:24.580728名無しさん@お腹いっぱい。
2015/06/09(火) 00:33:36.94>>726の場合は問題ない
0729名無しさん@お腹いっぱい。
2015/06/09(火) 01:25:54.94$ filename2=$(echo $filename1 | tr -d [0-9])
$ echo $filename2
foo.txt
0730名無しさん@お腹いっぱい。
2015/06/09(火) 01:49:15.59$ filename=123foo.txt
$ echo ${filename##*[0-9]}
foo.txt
0731名無しさん@お腹いっぱい。
2015/06/09(火) 08:44:03.74trか変数展開をつかうのか
自分は今まで何考えてたんだ
コマンド、変数展開を使いこなせてないことを痛感した
ありがとう
0732名無しさん@お腹いっぱい。
2015/06/11(木) 16:47:01.72foundfiles=$(find /hoge/hoge1 /foo/foo1 -name -type f *.txt)
for x in "${foundfiles}"
do
処理
done
としてみたのですが、うまくいきませんでした。
どこを直せばよいのでしょうか?
0733名無しさん@お腹いっぱい。
2015/06/11(木) 17:10:28.240734名無しさん@お腹いっぱい。
2015/06/11(木) 18:04:07.93foundfiles=$(find /hoge/hoge1 /foo/foo1 -name *.txt -type f)
for x in "${foundfiles}"
do
処理
done
これでokですか?まだ、怪しいとこありますか?
0735名無しさん@お腹いっぱい。
2015/06/11(木) 18:13:25.03気体通りになってるか確認して終わり
かまう奴はアホか
0736名無しさん@お腹いっぱい。
2015/06/11(木) 19:55:03.20豚
0737名無しさん@お腹いっぱい。
2015/06/12(金) 12:06:31.64for x in "${foundfiles}"
do
echo "$x"
done
とやると一見上手くいったように見えましたが、
foundfiles=$(find /hoge/hoge1 /foo/foo1 -name *.txt -type f)
for x in "${foundfiles}"
do
echo "${x##*/}"
echo "$x"
done
としてやると、初めのファイルのファイル名だけ出てきて、あとは検索結果が表示されるだけでした。
なにがまずかったのですか?直すことはできるのでしょうか? 👀
Rock54: Caution(BBR-MD5:0be15ced7fbdb9fdb4d0ce1929c1b82f)
0738名無しさん@お腹いっぱい。
2015/06/12(金) 13:33:39.96そのあたりがわかってないみたい
がんばれ
0739名無しさん@お腹いっぱい。
2015/06/12(金) 14:39:13.27なんでなんだろう?
for x in "$@"
というのをよく見かけるからまねしてました。
"${foundfiles}"は検索結果を1つの文字列にする。
なら、"$@"は?あれれ?
どういうことなのでしょうか?
0740名無しさん@お腹いっぱい。
2015/06/12(金) 14:43:19.06そうしない身に付かない
0741名無しさん@お腹いっぱい。
2015/06/12(金) 14:49:36.84for で変数に入れて回す場合、IFSに改行をセットして、区切ってもらうために変数をクォートはしない
#!/bin/sh -x
var='
a b c d e
2OrMoreSpaces between the words
x y z
'
IFS='
'
# for i in "${var}"
for i in ${var}
do
echo "=> $i <="
done
応援するよ。がんばって
0742741
2015/06/12(金) 15:27:47.27□E. 学習用テキスト
1. Bourne Shell自習テキスト ( 1993年 ) pdf お薦め
一応、引用しといた
man dash
@ Expands to the positional parameters, starting from one.
When the expansion occurs within double-quotes, each posi‐
tional parameter expands as a separate argument. If there
are no positional parameters, the expansion of @ generates
zero arguments, even when @ is double-quoted. What this
basically means, for example, is if $1 is “abc” and $2 is
“def ghi”, then "$@" expands to the two arguments:
"abc" "def ghi"
$1 が "abc"で、$2 が "def ghi" のとき、"$@" は "abc" "def ghi" に展開される
0743名無しさん@お腹いっぱい。
2015/06/12(金) 15:31:58.73訂正 man bash、man dash
0744名無しさん@お腹いっぱい。
2015/06/13(土) 13:45:25.05ネット上の記述とmanで今までなんとかこなせてたけど
基本がないとだめですね
早速、>>6を読んでみます
0745名無しさん@お腹いっぱい。
2015/06/13(土) 20:52:58.13foundfiles=( $(find /hoge/hoge1 /foo/foo1 -name *.txt -type f) ) ←配列にする
for x in "${foundfiles[@]}"
でおk
0746名無しさん@お腹いっぱい。
2015/06/15(月) 13:27:36.31それでできました
()はコマンド置換だけじゃないんですね
0747名無しさん@お腹いっぱい。
2015/06/15(月) 13:44:30.600748名無しさん@お腹いっぱい。
2015/06/15(月) 23:58:45.64-----------------------
#!/bin/bash
LAST=0
function test() {
LAST=$1
echo $LAST
}
echo "LAST=$LAST"
test 111
echo "LAST=$LAST"
x=$(test 222)
echo "LAST=$LAST x=$x"
--------------------------
を実行すると
LAST=0
111
LAST=111
LAST=111 x=222 ←なぜ LASTが 222に変更されないのか?
実際は関数のネストとかでもっと複雑だったんだが、
変な動作するようになってデバッグに苦労した・・・
0749名無しさん@お腹いっぱい。
2015/06/16(火) 00:33:43.810750名無しさん@お腹いっぱい。
2015/06/16(火) 00:48:56.390751名無しさん@お腹いっぱい。
2015/06/17(水) 12:27:35.75スペース入りファイル名に未対応、失格。
0752名無しさん@お腹いっぱい。
2015/06/17(水) 13:55:31.31では模範解答をどうぞ
0753名無しさん@お腹いっぱい。
2015/06/17(水) 20:41:26.360754名無しさん@お腹いっぱい。
2015/06/17(水) 21:21:37.470755名無しさん@お腹いっぱい。
2015/06/17(水) 21:25:36.37IFS_tmp=$IFS; IFS=$"\n"
0756名無しさん@お腹いっぱい。
2015/06/18(木) 05:55:23.840757名無しさん@お腹いっぱい。
2015/06/18(木) 07:35:13.140758名無しさん@お腹いっぱい。
2015/06/18(木) 07:48:16.570759名無しさん@お腹いっぱい。
2015/06/18(木) 10:04:59.96■ このスレッドは過去ログ倉庫に格納されています