2 回答

TA貢獻1843條經驗 獲得超7個贊
取指定字符之前的字符的方法是:
perl -nle 'if(/^start:/ or /^end:/){ # 匹配 flag
/([^:]+:)(.*)?\(?/; # 正則捕獲$1,$2,其中$1是start: 或 end:,$2是'('之前的部分
if($1 eq "start:"){push @{$hash{$1}},$2;$s=$2;} # 如果$1是start:的話,存入key為$1,值為$2的hash中,另外,再保留一份$2給臨時變量$s,
else{$hash{$s} = $1.$2} # 如果$1不是start:,即是end:, 則存入key為$s,值為$1.$2到hash中
};
END{
use Data::Dumper;
print Dumper \%hash; # 可以看下hash的結構是什么,應該會理解下面foreach的block部分
foreach (sort {$a cmp $b} @{$hash{"start:"}}){
print "start: ",$_,"\t",$hash{$_}
}
}' file

TA貢獻1873條經驗 獲得超9個贊
方法有三種,一般可以使用字符串搜索找到位置,然后獲取子串,方法二是模式匹配,我說說方法三,使用split,例如你的例子:
$Data='BRD1_EC2=3.887607(389.999986M,5)R =nail=2,17 value=0ohm PN=ZNO30V4.2JCMS1812 * TOP';
($s1,$s2)=split($Data,'_');
($s1)=split($s2,'=');
print $s1;
添加回答
舉報