検索条件
全2件
(1/1ページ)
$arr = ['a', 'b', 'c'];
$test1 = '';
$test2 = '';
$test3 = '';
for($idx = 0; count($arr) > $idx; $idx++) {
${'test' . ($idx + 1)} = $arr[$idx];
// $this->{'test' . ($idx + 1)} = $arr[$idx];とするとクラスのプロパティも行ける
}
// $test1 = 'a'
// $test2 = 'b'
// $test3 = 'c'
文字列を編集したりするのに大変便利なやつ。sedやawkの代わりに使える。構文はPerlそのものが使える。なにせPerlなので
-e
php -r
やnode -e
と同じ-n
$.
で行番号、$_
で行の文字列を取得できるwhile (<>)
相当の処理-p
print $_
相当の処理を実行する-l
$_
)から改行文字を削除し出力に改行を追加する-a
awk
相当の文字列分割処理を行う(autosplit mode with -n or -p)$F
に配列として入るので次のようにして取得できる
perl -ale 'print "$F[0] - $F[1]'
$#F
を指定すると分割した個数が取れる-F/pattern/
-a
でsplitするパターンを設定する-F,
とするとCSVを分割できる-i[ext]
perl -i -pe 's/aaa/xxx/' foo.txt
-i.bak
のように指定するとバックアップファイルが作成される-ipe
のようには使えない)変数を指定しない場合、基本的に$_
として扱われる
print
print $_
と同じ挙動をする$hoge =~ s/foo/bar/
/(.+)/; print $1
echo hoge.jpg | perl -ne '/(.+)./; print $1'
$_
echo aaabbc | perl -ne 's/c/d/; print'
の出力はaaabbd
となるEND{}
-n
, -p
を指定した場合、END{}
は$_
が取れないので渡す場合は$x = $_; END{ print $x }
のように別の変数に代入する必要がある一例
ls -l | perl -ale '$F[8] =~ s/\.html//; print "$F[8]";'
1のところが行数なので、ここを変えることで任意の行の文字列を取れる
perl -ne 'print if $. == 1'
echo "foo bar" | perl -pe 's/(?<first>.+) (?<last>.+)/$+{first}-$+{last}/'
unshift
で配列の先頭に値を追加し、END{}
で最後に出力している
cat <<EOF | perl -ne 'unshift @x, $_; END{ print @x }'
aaa
bbb
ccc
EOF