Chinaunix首页 | 论坛 | 博客
  • 博客访问: 390724
  • 博文数量: 117
  • 博客积分: 4416
  • 博客等级: 上校
  • 技术积分: 1135
  • 用 户 组: 普通用户
  • 注册时间: 2009-06-08 14:16
个人简介

一生醉生忘死,就让他继续下去吧!

文章分类

全部博文(117)

分类: LINUX

2009-06-22 16:45:12

双引号内的转义字符
\n ===>换行
\r ===>回车
\t ===>水平制表符
\f ===>换页符
\b ===>退格符
\a ===>喇叭
\e ===>ESC(ASCII编码的转义字符)
\007 ===>八进制的ascii码,发声
\x7f ===>十六进制的ASCII码
\cC  ===>“ctrl+C"
\l   ===>将下个字符转换成小写
\L   ===>将到\E为止的所有字符转为小写
\u   ===>将下个字符转为大写
\U   ===>将到\E为止的所有字符转换为大写
\Q   ===>将到\E为止的非文字字符加上反斜线
\E   ===>结束\L,\U或\Q

字符串操作符
"A"."B"                      #结果等同于"AB"
"A".' '."B"                  #等同于"A B"
"A"."\n"                     #等同于"A\n"
"A" x 3                      #等同于 "AAA"
5 x 4                        #等同于 "5555"

警告信息的几种显示设定方法
$perl -w program   ===>直接在shell里执行
#!/usr/bin/perl -w  =====>在脚本第一行设定
#!/user/bin/perl
use warnings;      ======>脚本第二行设定
use diagnostics;   ======>更详细的警告说明
$perl -Mdiagnostics ./my_program ====>外部调用

############# 注意:perl中使用变量,必须在变量前加$,这个shell中不同
双目赋值操作符
$A+=3;
$A*=3;
$A.=" ";
$A**=3   ===>$A的3次方
 
${str}  ======>对区分表示的变量,必要时使用{}来把变量名与后面连着的字符串相分离
操作符的结合性与优先级(从高到低)
结合性操作符
左  括号和列表操作符的参数
左  ->
++  --(自增和自减)
右  **
右  \ ! ~ + - (一元操作符)
左  =~ !~
左  * / % x
左  + - . (二元操作符)
左  << >>
    命名的单目操作符 (-X 文件色是, rand)
    < <= > >= lt le gt ge(“不等的”)
    == != <=> eq ne cmp(“相等的”)
左  &
左  | ^
左  &&
左  ||
右  ?:(三目操作符)
右  = += -= .=
左  , =>
    列表操作符(向右结合)
右  not
左  And
左  or xor

=======>数值与字符串的比较操作符
                  数字    字符串
相等               ==      eq
不等               !=      ne
小于               <       lt
大于               >       gt
小于或等于         <=      le
大于或等于         >=      ge
#############注意:对于数值比较或字符串,返回的一律都是“true”或“false",字符串比较会逐
一对比两个字符串里的字符,判断是否相等或者哪个排在哪个前面(在ASCII中,大写字母排在小写字
母的前面)

chomp的用法====>删除行末的换行符
chomp($text=);
$betty=chomp $food===>if $fod 结尾处有换行符 ,return 1,else return 0

if 与 while循环语句
if (condition) {command};else {command};
while (condition) {command};

判断某个字符串是否是空字符串,可以用defined函数
例: if (defined($mada)){
  print "The input is $mada"
  }
  else {
  print "no input \n"
  }

===>列表的二种形式
   (1,2,3)
   (1..100)
   ($a..$b)
   (0..$#rocks)

qw ! a b c d!
qw < a b c d >
qw ( a b c d )
qw { a b c d }
qw [ a b c d ]

=====>交换变量
     ($fred,$barney)=($barney,$fred)
     ($betty[0],$betty[1])=($betty[1],$betty[0])
用列表赋值
        ($fred,$barney)=qw
        ($rocks[0],$rocks[1],$rocks[2])=qw /a b c/
给数组赋值
        @giant=1..1e5;
        @giant=(@rocks,"file",@dino)

pop操作符====>取出数组最后一个元素,返回它
例:   $a=pop @array  ====>弹出最后一个元素,并把它赋值给变量a
push操作符====>在数组尾部压入一个元素
例:   push(@array,0)
       push(@array ,1..10)
       push @array ,@other
shift操作符====>弹出数组第一个元素,返回它
例    shift @array
unshift 操作符====>在数组第一个元素前压入一个元素
例:  unshift @array,4   ====>压入4

数组名与变量名的混淆
@fred=qw(eating rocks is wrong);
$fred="right";
print "this is $fred[3]\n"; ====>wrong
print "this is ${fred}[3]\n"; ====>right

foreach 循环
例     foreach $rock (qw/badrock slate lava/)
      {
        print "$rock\n";
      }

reverse 操作符===>反序返回列表
例      @fred=6..10;
        @barney=reverse(@fred);
        @barney=reverse 6..10;====>与上面作用相同
sort 操作符====>按照assii编码顺序排序

       @b=sort(@rocks);
       @b=sort 97..102; ===>100,101,102,97,98,98,99


====>
1、在标量上下文中,会返回输入数据的下一行
   $a= ====>输入一行接回车后,返回空行
2、在列表上下文中,会返回剩余的各行
   @a= ====>返回的每一行成为列表中单独的元素,按ctrl+D 停止输入

删除换行符
 @lines=;
 chomp @lines;

更简便点的写法chomp(@lines=);

子例程  sub marine {
                      $n+=1;  ====>全局变量$n
                      print;
                   }
     &marine ===>调用子例程

 特殊数组变量@_====>存储参数列表
例:       sub max {
               if ($_[0]>$_[1]) {
                 $_[0];
                }
               else {
                     $_[1];
               }

私有变量
         my($m,$n);
         my($m,$n)=@_;
        =======>把第1、2个参数赋给私有变量$m,$n

sub max {
      if(@_!=2) {      =====>@_变为标量
     print "only need 2 arguments"
     }




$maximun=&max(3,4,5,6);
sub max {
   my($max_number)=shift @_;
   foreach (@_) {
      if ($_>$max_number) {
            $max_number=$_;
       }
   }
$max_number;
}
print $maximun;

use strict;
         

  1 #!/usr/bin/perl -w
  2 use strict;
  3 my @name=qw/fred barney betty dino wilma pebbles bamm-bamm /;
  4 my $result=&which_element_is("dino",@name);
  5 sub which_element_is {
  6         my($var,@list)=@_;
  7         foreach (1..$#list) {
  8         if ($var eq $list[$_]) {
  9             return $_;
 10         }
 11         }
 12     }
~          

=======>格式化输出printf

printf "Hello,$s;your password expires in %d days!\n",$user,$day_to_dir;
printf 的几个参数 %g====>自动选择浮点数/整数/指数
                %d=====>整数,会舍去小数点后面的数字
                %s=====>字符串

指定小数点位数 printf “%12.3f\n”, 6*7 + 2/3;=====>_______42.667
            printf “%12.0f\n”, 6*7 + 2/3;======>___________42


printf“The items are:\n”. (“%10s\n”x @items), @items;



文件句柄(filehandle)是Perl 程序I/O 连接的名字,是Perl 和外界的纽带。也就是说,它是连接的名字,而非文件的名字。
Perl 自身有六个文件句柄:STDIN,STDOUT,STDERR,DATA,ARGV,ARGVOUT◆。
$ ./your_program Wilma===>指定输入/输出文件

if(! open LOG,">>logfile")
{
    die "can't creat logfile:$!";
}

if (@ARGV==0)====>没有输入参数
 {
         die "argument can't be null";
     }



  1 #!/usr/bin/perl
  2 open PASSWD,"  3     or die "denny to enter";
  4 open OP,">>log";
  5 while ()
  6 {
  7         chomp($_);
  8         print OP "$_";
  9         system `sleep 1`;=====>外部命令调用,可以换成exec
    }


========================散   列================
%hash=====>整个散列的表示
$hash{$key}=====>散列单个值的表示
%hash=("foo",3,"bbs",4,"ddd",5)
%hash=reverse %any_hash====> 散列的反转
散列的另一种表示方法:
my %last_name={
    "fred"=>"fly",
    "dino"=>undef,
    "betty"=>"rubble",
};

my %hash=("a"=>1,"b"=>2,"c"=>3);
my @k=key %hash;       ===>键函数keys
my @v=values %hash;    ===>值函数values
if (%hash) {
   print "....";
}
======>至少有一组键/值的话....
each %hash====>each函数,返回键/值列表
例子:
   while (($key,$value)=each %hash) {
     print "$key==>$value";
    }
 
  foreach $key (sort keys %hash) {
    $value=$hash($key);
    print "$key==>$value\n";
}

if (exists $books{"dino"}) {   ===>散列books中存在dino key键的话
   print "..";
}

my $person="betty";
delete $books{$person};

============>正则表达式<=========

1.  "." 通配符,表示单字字符,不包括换行符
2.  "\w" 数字、字母、下划线三种字符 \W表示非这三种字符
3.  "\d" 数字,\D表示非数字
4.  "\s" 空白字符,包括[\n\f\t\r],\S表示非空白字符

量词
1.  "?" 表示前一个字符的0次或1次
2.  "*" 表示前一个字符的0次或多次
3.  "+" 表示前一字符的1次或者多次

以正则表达式表示匹配
(/pattern/option)
option包括:
1. "s" ===>当pattern里有"."时,可以匹配包括换行符,默认的"."无法匹配换行符
2. "i" ===>忽视pattern里的大小写,全部匹配
3. "x" ===>忽视pattern中的空白符,为了美观

两种锚点:
1.匹配行,例: /^\s*$/
2.匹配单词,例:/\bfred\b/ 匹配单词的头尾两端,\B表示非单词边界锚点

绑定操作符=~,例: if ($var=~/\bfred/) {...}
                my $var=(STDIN=~/\bfred/)===>把匹配与否的布尔值传给变量$var

匹配变量
         if ("Hello ketty, run"=~/(\S+) (\w+,) (\S+)) {
           print "$1===$2===$3";
         }

自动变量匹配
1. "$&"   ===> 表示模式匹配部分
2. "$`"   ===> 表示模式匹配的前面部分
3. "$'"   ===> 表示模式匹配的后面部分

对模式匹配次数的表示
/pattern{n,m}/

s替换操作的几种表示方法:
s/pattern1/results/
s#pattern1#results#
s[pattern1][results]
s{pattern1}{results}

s替换操作的几个选项
1.s/a/b/g   ===>全部替换
2.s/a/\Ub/  ===>替换后的部分,全部转化为大写,\u只影响第一个字符
3.s/a/\Lb/  ===>替换后的部分,全部转化为小写,\l只影响第一个字符

split操作符:
例 @fields=split /separator/,$string;
   my @fields=split ===> 用空白符拆解$_;
join 操作符:
   my $result=join $separator,@pieeces;
   my $x=join ":",4,5,6,7,8

列表上下文中的 m//
       $_="Hello there, neighbor!";
       my($first,$second,$third)=(\S+ \S+, \S+);===>针对$_,不用=~
       print "....";

       my $text="...";
       my @words=($text=~/([a-z]+)/ig);

贪心量词与非贪心量词
+   对应  +?
*        *?

 例:   s#(.*)#$1#g; 对应 s#(.*?)#$1#g;

   my $data = "Barney Rubble Fred FlintstoneWilma Flintstone";
   my %last_name=($data=~/(\w+)\s+(\w+)/g);
   foreach (keys %last_name) {
   print "$_====$last_name{$_}\n";
   }
====>匹配$1,$2的组成键值对,赋值给散列last_time

open FILE, $filename
or die “Can’t open ‘$filename’: $!”;
my $lines = join '', ;
$lines =~ s/^/$filename: /gm;

#!/usr/bin/perl -w
use strict;
chomp(my $date = `date`);  ===>等同chomp(my $date=localtime)
$^I =".bak";    ===>指定备份文件
my $file=;
open FILE,"$file";
while(){
        s/^Author:.*/Author: Randal L. Scharwartz/;
        s/^Phone:.*\n//;
        s/^Date:.*/Date: $date/;
        s/1/aaa/;
        print;
}


取消()的记忆功能,在(后紧跟?:  会取消该()指定的变量在内存中的存储
例: if (/(?:bronto)?saurus (?:BBQ )?(steak|burger)/) {
       print “Fred wants a $1\n”;
     }

for 循环的怪异变化
     for($_ = “bedrock”; s/(.)//; ){ #如果s///成功则进入循环
        print “One character is: $1\n”;
}

循环控制:
1、last====>立即终止当前循环
2、next====>跳出此次循环,进入下一次循环
3、redo====>跳到当前循环块的顶端,不经过任何测试条件,重新执行代码

next例子:
while (<>) {
  foreach (split) {
     $total++;
     next if (/\W/);   ===>当非word时候,跳出此次循环,进入下一次循环
     $valid++;
     $count{$_}++;     ===>对散列进行赋值
}
}
print "total things=$total,valid words=$valid\n";
foreach $word (sort keys %count) {
   print "$word was seen $count{$word} times.\n";
}


文件测试
例:die ".....\n" if -e $filename ===>存在文件filename则die
   warn " ....\n" if -M "file">28;===>文件修改时间离现在已经超过28天

检测选项含义
-r 文件或目录对此(有效的)用户(effective user)或组是可读的
-w 文件或目录对此(有效的)用户或组是可写的
-x 文件或目录对此(有效的)用户或组是可执行的
-o 文件或目录由本(有效的)用户所有
-R 文件或目录对此用户(real user)或组是可读的
-W 文件或目录对此用户或组是可写的
-X 文件或目录对此用户或组是可执行的
-O 文件或目录由本用户所有
-e 文件或目录名存在
-z 文件存在,大小为0(目录恒为false)
-s 文件或目录存在,大小大于0(返回值为文件的大小,单位:字节)
-f 为普通文本
-d 为目录
-l 为符号链接
-S 为socket
-p 为管道(Entry is a named pipe(a“fifo”))
-b 为block-special 文件(如挂载磁盘)
-c 为character-special 文件(如I/O 设备)
-u setuid 的文件或目录
-g setgid 的文件或目录
-k File or directory has the sticky bit set
-t 文件句柄为TTY(具有交互的能力)(系统函数isatty()的返回结果;不能对文件名使用这个测试)
-T 文件有些像“文本”文件
-B 文件有些像“二进制”文件
-M 修改距今的时间(单位:天)
-A 访问距今的时间(单位:天)
-C 索引节点修改距今的时间(单位:天)

例子 if (-f "file) {
      die "ffffff\n";
    }
    my $size=(-s)/1000;====>$_变量表示的文件算k

stat 与lstat(针对链接文件)
my ($dev,$ino,$nlink,$uid,$gid,$rdev,$size,$atime,$mtime,$ctime,$blksize,$blocks)
=stat($filename);
$dev ===>文件的设备号
$ino ===>节点号
$mode===>权限位
$nlink===>硬链接数
$uid/gid===>用户标识符与组标识符
$size===>以字节单位的文件大小
$atime/mtime/ctime===> 文件访问时间/修改时间/创建时间

$time=localtime;====>取得当前的时间

位运算操作符
1、&    ====>两边都为1
2、|    ====>两边只要有1个1
3、^    ====>两边只能有1个1

6<<2,把左边操作数左移2位置,多余的补零
6>>2,右移,减少位数
~10,逐位否定,取反

hex($var)====> 十六进制转换为十进制



===============目录操作=========================
chdir "/etc/" or die "cant't change to /etc:$!";

cat>show-args
foreach $args ($ARGV){
print "one args is $args";
}
perl show-args *.txt          ====>显示目录下txt后缀的文件

my @var=glob "*";             ====>找到当前目录下的所有文件,但不包括以.号开头的文件
my @var=glob ".*";          ====>所有文件
my @var=<*>                 ====>同上

my $dir_to_process="/etc";=====>读入目录句柄,通过目录句柄显示文件
opendir DH,$dir_to_process or die "can'topen $dir_to_process";
foreach $file (readdir DH) { ====>等价于while (my $file=readdir DH) {
        next unless ($file=~/\.d$/);====>过滤掉非以.d结尾的文件
        print "$dir_to_process/$file\n";====>$dir_to_process为文件前的路径

}

删除文件:unlink glob "*.o"; ===>返回值表示删除了多少个文件
        rename "old","new";
 
 
====>批量修改文件名
foreach my $file (glob “*.old”){
my $newfile = $file;
$newfile =~ s/\ .old$/.new/; ===>左边为正则,所以加\,右边表达式,不用
if (-e $newfile){
warn“can’t rename $file to $newfile: $newfile exists\n”;
}elsif(rename $file, $newfile){
##成功,什么也不做
} else {
warn “rename $file to $newfile failed: $!\n”;
}
}
 
硬链接
link“chicken”, “egg”    ====>innode号相同,修改一个,另一个修改
or warn “Can’t link chicken to egg: $!”;
软链接(符号链接)
symlink “dodgson”, “carroll”  ===>只是一个符号链接,与真实文件不同
or warn “Can’t sysmlink Dodgson to carroll: $!”;
my $where = readlink “carroll”; #得到符号链接的地址
my $perl = readlink“/usr/local/bin/perl”#可能得到Perl 放置的地方

建立与移除目录
mkdir "fred",0755 or warn "aaa";
rmdir $_ for glob "fred/*"    ===>移除目录fred下所有空目录
foreach my $dir (qw(fred barney betty)){
     rmdir $dir or warn "can't rmdir $dir "
}
unlink glob "$temp_dir/* $temp+dir/.*"; ====>删除$temp_dir的内容

修改权限
chmod 0755,"fred","barney"

更改隶属关系
my $user=1004;
my $group=100;
chown $user,$group,glob "*.o";

处理字符串名的用户名与组名,使用 getpwnam
defined(my $user=getpwam "merlyn")or die "bad user"
defined(my $group=getpwam "dock")or die "bad group"
chown $user,$group ,glob "/home/merlyn/*";
=====defined 函数确认返回值是不是undef

更改时间戳
my $now=time;
my $ago=$now-24*60*60;
utime $now,$ago,glob "*";   ===>将访问时间修改成现在,修改时间设成一天以前,另外还有个$ctime表示更改时间

字符串与排序
index函数====>返回某个字符串在大串中的第一次出现的位置
例:
           $here="Howdy world!"
           my $target1=index($here,"w") ====>$target1 返回2
           my $target2=index($here,"w",$target1+1) ====>第三个参数,表示从$target1后的一个位置查找,当找不到的时候,会返回-1

rindex====>返回某个字符串在大串中的最后一次出现的位置
           my $last_slash=rindex("/etc/passwd","/"); ====>值为4


substr函数====>字串操作
my $mineral=substr("Fred J.Flintstone",8,5)====>返回字符串第9个及后面4个字符,参数5省略,表示返回第九个及后面的字符,当参数5为-5时,表示从倒数第4个字符,返回字符
substr($string, -20) =~ s/fred/barney/g;====>在指定范围内替换匹配的字符串
my $previous_value = substr($string, 0, 5, “Goodbye”);====>与上面功能相同
 
printf 与sprintf之间的不同
printf与sprintf的参数格式完全相同,printf直接打印,sprintf返回打印值
 
my $data_tag = sprintf
“%4d/%02d/%02d %02d:%02d:%02d”,
$yr, $mo, $da, $h, $m, $s;    ====>打印日期,存入变量

my $money = sprintf “%.2f”, 2.49997;=====>留两位得到2.50
 
sub big_money {
my $number = sprintf “%.2f”, shift @_;
#在do-nothing 循环中,每一次加入一个逗号
1 while $number =~ s/^(-?\d+) (\d\d\d)/$1,$2/;
#将美元符号放入合适的位置
$number =~ s/^(-?)/$1\$/;
$number;
}
 
 
按数字排序的两种方法
一、
sub by_number {
if($a < $b){-1} elsif($a > $b){1} else {0}
}
my @result = sort by_number @some_numbers;
二、
sub by_number {$a <=> $b }
my @result = sort by_number @some_numbers;
按字符串排序
sub ASCIIbetically {$a cmp $b} my @string = sort ASCIIbetically @any_strings;
 
sub case_insenstive {“\L$a”cmp “\L$b”}====>比较两个字符串,而忽略大小写
 
my @descending = reverse sort { $a <=> $b } @some_numbers;===>由小到大排序
 
对hash排序
my %score = (“barney”=>, “fred”=>205, “dino”=> 30);
sub by_socre { $score{$b} <=> $score{$a}};
my @winners = sort by_score keys %score;
 
=======>假设值有相通的情况下,按字符串keys值排序
my @winners = sort by_score_and_name keys %score;
sub by_score_and_name {
$score{$b} <=> $score{$a} #按照降序的成绩
or
$a cmp $b; #字母顺序的名字
}

======>五级排序
@patrons_IDs = sort {
&fines($b) <=> &fines($a) or
$items{$b} <=> $items{$a} or
$family_name{$a} cmp $family_name{$a} or
$personal_name{$a} cmp $family_name{$b} or
 
 
=============================================================================
系统外部命令的调用
例: system“date”
    system ‘ls–l $HOME’;
    system “ls–l \$HOME”;    ====>用双引号会设内部进行变量替换,所以要加\来转义







阅读(1753) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~