我覺得用點點也不錯
就split那行不同而已
chomp (my $name = <>);
my @record;
open F, 'text';
while (<F>) {
chomp, push @record, $_ if /^$name score$/../^end $name$/;
}
close F;
不過題外話 如果push那邊省略$_就會爛掉 真是猜不透perl啊
※ 引述《scwg ( )》之銘言:
: 我的作法是這樣
: chomp (my $name = <>);
: my @record;
: open F, 'text';
: {
: local $/ = '';
: while (<F>) {
: @record = split /\n/ if /^$name score/;
: }
: }
: close F;
: $" = '|';
: print "@record\n";
: 重點是
: local $/ = '';
: $/ 是 perl 特殊變數, 表示用 <...> 讀檔/輸入時, 讀到什麼為止;
: 預設為 "\n" 表示一次讀一行.
: $/ 有兩個特例值: undef 和 ''. $/ = undef 表示把讀到檔尾 (slurp mode).
: $/ = '' 表示一次讀一『段』 (paragraph mode). 段與段之間以空行分開.
: 因為你的資料符合 paragraph mode 的格式, 所以適合把 $/ 設成 '',
: 一次讀一筆進來檢查最開始 ( /^.../ ) 是不是 /$name score/.
: 如果找到了再用 split 把各行切開.
: ※ 引述《pat12345 (咖啡杯)》之銘言:
: : 各位perl版的朋友大家晚安,
: : 有一個regular expression的問題想要請教大家,
: : 看似很簡單,想要寫出來卻摸不著頭緒,
: : 想要問問大家有沒有什麼想法,
: : 下列是個純文字檔,
: : 我想要給個輸入的參數Nelson,
: : 然後萃取一個陣列,
: : 陣列0~4 分別為最後面的五行。
: : 這有辦法做到嗎@@?
: : *****************txt*****************************
: : Jack score
: : 100
: : 80
: : 90
: : end Jack
: : Peter score
: : 90
: : 88
: : 75
: : end Peter
: : Nelson score
: : 33
: : 55
: : 78
: : end Nelson
: : *************************************************