博客
关于我
Perl基础学习01之标量数据
阅读量:386 次
发布时间:2019-03-05

本文共 3599 字,大约阅读时间需要 11 分钟。

Perl语言中标量数据主要指数字标量和字符串标量,本篇主要介绍Perl中数字标量字符串标量的相关基础知识。

目录



1 数字

  • 浮点数

3.25e20 3.25乘以25的20次方;

  • 整数

1415926 1_415_926,Perl允许整数之间加下划线以便以清楚可识别。

例如,int1.pl

#!/usr/bin/perluse strict;use warnings;my $int1 = 1_415_926;print "$int1\n";

perl int1.pl

1415926

  • 数字操作符

加(+),减(-),乘(*),除(/),取模(%),求幂(2**3为2的3次方等于8)

例如,compute.pl

#!/usr/bin/perlmy $compute_result = 10%4;print "$compute_result\n";

perl compute.pl

2

2 字符串

  • 单引号(A single-quoted string literal)

支持转义,引号内的任何字符都是字符本身,例如,\n不是换行符,\t不是tab键

例如,string1.pl

#!/usr/bin/perluse strict;use warnings;my $string1 = 'perl\t\n';my $string2 = 'perl\\t\\n'; #此时\t \n分别表示tab键和换行符;print "$string1\n";print "$string2\n";

perl string1.pl

perl\t\n

perl\t\n 

  • 双引号(A single-quoted string literal)

\ 此时表示特殊含义

例如,string2.pl

#!/usr/bin/perluse strict;use warnings;my $string1 = "perl\tperl1\n"; #\t表示tab,\n表示换行;print "$string1\n";
  • 字符串操作符

句点操作符

句点操作符(.),连接句点前后的字符串,句点前后的字符不会发生任何修改。

例如,string3.pl

#!/usr/bin/perluse strict;use warnings;my $string1 = "Come";my $string2 = "on!";my $string3 = $string1.$string2;print "$string3\n";print "$string1"." "."$string2"."\n";#string1 空格 string2

perl string3.pl

Comeon!

Come on!

  • 重复操作符

重复操作符(string repetition operator),将字符拷贝多次,当次数为非整数时,向下取整(若4.8则取5)

例如,string4.pl

#!/usr/bin/perluse strict;use warnings;my $string4 = "Comeon!\t"x3;my $string5 = "Comeon!\t"x3.5;print "$string4\n";print "$string5\n"; perl string4.pl

perl string4.pl

Comeon! Comeon! Comeon!

Comeon! Comeon! Comeon! 

  • 数字与字符串之间的转换

Perl会根据操作符自动完成转换,使用者只需正确使用操作符。

例如,string5.pl

#!/usr/bin/perluse strict;use warnings;my $string6 = "12fred34" * "3";my $string7 = "Z" . 5 * 7;print "$string6\n";print "$string7\n";

perl string5.pl

Argument "12fred34" isn't numeric in multiplication (*) at string6.pl line 5. #Perl会发出警告

36

Z35

3 标量变量

存储一个值的变量,变量名称在整个程序中保持不变,但是变量值可以随着程序执行发生改变。

  • 变量命名规则

以$符号(魔符sigil)开头,后接变量标识符;

变量标识符由字母、数字及下划线构成,但是变量标识符的首字符不能为数字;

变量名称区分大小写,例如,$SCALAR 与$scalar不同;

  • 标量等号赋值

$fred = 17; #将17使用赋值符等号赋值给变量$fred

  • 标量双目赋值符赋值

例如,$scalar = $scalar + 4; 等价于$scalar += 4;

  • 字符串变量内插

在字符串中引用另外一个变量。

例如,string6.pl

#!/usr/bin/perluse strict;use warnings;my $string6 = "Lady cai";my $string7 = "I like $string6 !";print "$string7\n";

perl string6.pl

I like Lady cai !

 

  •  数值标量与字符标量比较操作符

数值标量		字符标量		含义==		eq		等于!=		ne		不等与<		lt		小于>		gt		大于<=		le		小于等于>=		ge		大于等于
  • chomp函数

去掉字符串末尾换行符,chomp()函数的返回值是

例如,chomp1.pl

#!/usr/bin/perluse strict;use warnings;my $text = "Start from here\n";print "$text\n";#此处会输出两个换行符my $text1 = chomp ($text);# 返回值为去掉的字符个数,去掉1个\n,所以输出为1print "$text\n";#此处只输出一个换行符print "$text1\n";

perl chomp1.pl

Start from here

 

Start from here

1

chop函数

去掉末尾字符

例如,chop.pl

#!/usr/bin/perluse strict;use warnings;my $scalar1="Perl";my $chop1=chop $scalar1;#返回去掉的值,修改原字符print "$scalar1\n";print "$chop1\n";

perl chop.pl

Per

l

 

substr函数

取出字符一部分,语法如下:

substr EXPR,OFFSET,LENGTH,REPLACEMENT

EXPR,待处理字符串

OFFSET,处理起始位置为0时,从第一个字符开始,为负时从右端开始

LENGTH,如果不提供值,从起始位置至末尾

REPLACEMENT,替换取出的字符

例如,substr1.pl

 

#!/usr/bin/perluse strict;use warnings;my $string="I love LadyCai";my $substr1=substr $string,1;my $substr2=substr $string,1,3;my $substr3=substr $string,1,3,"XX";print "$substr1\n";print "$substr2\n";print "$substr3\n";print "$string\n";#原字符已改变

 

perl substr1.pl

love LadyCai

lo

lo

split函数

将字符串分割为一个数组。

语法:split /PATTERN/,EXPR,LIMIT

  • If only PATTERN is given, EXPR defaults to ;
  • PATTERN,分隔符,可以是正则,可以同时指定多个分隔符,defaults是 " ",省略分隔符所有连续空白都会被当作单个分隔符;
  • LIMIT,表示最多分割为几个元素,defaults为1,若则表示尽可能多地分隔。
#limit,限制分割次数 print join(':', split(//, 'abc', 1)), "\n"; #abc print join(':', split(//, 'abc', 2)), "\n"; #a:bc print join(':', split(//, 'abc', 3)), "\n"; #a:b:c print join(':', split(//, 'abc', 4)), "\n"; #a:b:c

 4 参考资料

 

 

 

 

 

 

 

 

 

 

转载地址:http://bbmwz.baihongyu.com/

你可能感兴趣的文章
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql skip-grant-tables_MySQL root用户忘记密码怎么办?修改密码方法:skip-grant-tables
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql sysbench测试安装及命令
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
MySQL Troubleshoting:Waiting on query cache mutex
查看>>
mysql union orderby 无效
查看>>
mysql v$session_Oracle 进程查看v$session
查看>>
mysql where中如何判断不为空
查看>>
MySQL Workbench 使用手册:从入门到精通
查看>>
MySQL Workbench 数据库建模详解:从设计到实践
查看>>
MySQL Workbench 数据建模全解析:从基础到实践
查看>>