#!/usr/bin/perl -w # 标准的头部写法,-w意为显示警告
$a=$b+10 # $a和$b都不需要定义,拿过来就用
Note: $flag=0
如果后续未用到,会爆警告
@array=() # 声明一个空数组 $array[1] # 取数组中的第2个值 $len=@array # 取数组的长度 $#array # 取数组最后一位值的下标 $array [0..4] # 取数组第1到第5个数 @array=(1..25) # 构建一个包含从1到25的数组 print @lines[0..$#lines] # 将一个数组从第1个到最后一个元素全部打印出来
push @array,$i # 将变量i插入到数组最后 pop @array # 删除最后一个值 shift @array # 弹出数组第一个值(常配合@ARGV)
判断每一位是否相同
$index=0; while($index<@arr1) { if($arr1[$index] ne $arr2[$index]) { # to do } $index++; }
$aim = 263; if(grep /^$aim$/,@arr1) # 使用grep判断字符$aim是否在@array中 { print "find\n"; }
@words1=("a","b","A","d","c"); @words2=("repaaaaaalace", "raplace", "input", "sequence", "of", "a", "repaalace", "character"); my @newwords1=sort @words1; #以ASCII进行排序,非字典顺序 my @newwords2=sort @words2; print "@newwords1\n"; print "-----\n"; print "@newwords2\n"; 输出: A a b c d ----- a character input of raplace repaaaaaalace repaalace sequence
@num=(1,24,35,0); my @sorted = sort { $a <=> $b }@num; print "@sorted\n"; 输出: 0 1 24 35
join函数
@num=(1,24,35,0); my @str = join("-",@num); print "@str\n"; 输出: 1-24-35-0
if(条件1 || 条件2 && 条件3) { }elsif(条件) { # 注意此处为elsif }else { }
条件判断
eq,ne,gt,le # 进行字符串比较,前面不带- == 和 != # 数字匹配
# 第一种 for(my $i;$i<$len;$i=$i+1) { } # 第二种 foreach my $i (@array) { }
last; # 退出循环 last与next last # 直接跳出循环体 类似break next # 跳出本次循环 exit exit 0; # 退出并返回0,也可以直接 exit; 不带返回值
$line1=chomp($line)
可用于去除$line中最后的\n,也可以使用正则去掉
$i=sqrt(100)
开平方
lc() # 将字符全部小写 uc() # 将字符全部大写
glob 函数用于打印作为参数传递给它的目录中存在的文件。此功能可以打印所有或扩展名已传递给它的特定文件
foreach $file (glob "lyrics/*") { # 遍历lyrics目录下所有文件 }
rand(5)
生成一个0-5之间的一个随机float型数,如3.1415926
int rand(5)
取整,结果为3(接上假设)
./a.pl运行后 ,enter换行, 再次输入的内容使用<>读取
./digit.pl <1.txt
./digit.pl hello world <1.txt
读进去的内容分割成单词加入一个数组
while ($line = <STDIN>) { my @words = split /[^a-zA-Z]+/, $line; foreach $word (@words) { $count++ if $word ne ''; } }
同一行的输入参数大多用@ARGV和open来读
如果单单使用while(<>)是读取不到7的
@ARGV # 包含外界所有传入参数的一个数组 $len=@ARGV # 数组长度 $ARGV[0] # 外界传入的第一个参数 例:./echon.pl <t1.txt t2.txt t3.txt @ARGV=("t2.txt","t3.txt") 由于第一个参数含有重定向<,所以不会被放入ARGV中 $len=@ARGV 是 2 $ARGV[0] 是 t2.txt ------------ shift @ARGV # 将外界输入参数第一位弹出来 例: ./digit.pl -5 1.txt shift @ARGV # 操作之后可以直接对@ARGV进行操作,即操作1.txt
open F,'<',t1.txt or die "$0: Can't open $file: $!\n"; 将t1.txt打开至 F中,后续可以对<F>进行操作,如@array=<F> close F;
print("\n") 可以实现换行 print('\n') 会把\n打印出来 print $out $line 注意这种写法,意思为在$out里写入$line(不可以加括号)
length($line) 获取字符串的长度
$str=substr($line,2,10) 从第3个字符开始获取$line中总计10个字符(类似切片)
$a.="hello world" 字符串相加
split函数
my @words=split(/ /,$text); # 将text中的内容以空格间隔,重新加入数组words中 例子: $line="a b c d 1" 输出结果: @words={a,b,c,d,1}
sub test{ # test后面不加() my ($test,$test1)=@_; # @_意为外界传进来的实参,可传多值 print($test); return $test+$test1; # 同样使用return来返回值 } test(1,2);
哈希(字典)
%data={'today','818','tomorrow','819','yesterday','817'} # 通过逗号隔开 $data{'today'} # 读取某一键的值 读取今天,818 @names = keys %data; # 读取所有的key @values = values %data; # 读取所有的value $data{'thedaybeforeyesterday'}='816'; # 直接赋值即可添加键值对 delete $data{'today'} # 通过delete删除键值
=~ # 匹配 !~ # 不匹配 if($i=~/-([0-9]+)/) { print($1); # 重点知识:$1为正则匹配中第一个括号里内容,$2为第二括号内内容 } //i # 匹配忽略大小写 ---------------------- $1,$2是只读无法改变的,可使用$num=$1 去进行后续操作 将匹配结果赋值给另一个值 a=b=~//;
s///g # 替换字符,g表示全局匹配 例:s/[01234]/</gi; # 将字符串里所有的01234替换成< $i =~ s/[1234]/</gi; # 将变量i中所有的1234替换成< $line =~ s/^\s*//; # 去掉开头空白格 $line =~ a/\s*$//; # 去掉末尾的空白格 补充: \w # 匹配一个字母、数字或下划线 \d # 匹配一个数字,同[0123456789] \s # 匹配一个空格 [^0-9] # 匹配纯数字 [^a-zA-Z] # 匹配非字母
shell是将整个文件读进来,通过某一个关键字匹配去获取一整行内容
perl是将一整个文件逐行读进来,通过匹配来得到一行中某些特定的字段,加上使用group($1)来配合提取某些字段