Perl 变量类型

Perl 变量类型

Perl 主要有三种变量类型:标量($)、数组(@)和哈希(%)。标量存储单个值,数组存储有序列表,哈希存储键值对。

perl 复制代码
$scalar = "Hello";       # 标量
@array = (1, 2, 3);      # 数组
%hash = ("a" => 1, "b" => 2); # 哈希

Perl 条件语句

Perl 使用 ifelsifelse 进行条件判断。条件表达式需用括号包裹,代码块用花括号界定。

perl 复制代码
if ($age < 18) {
    print "未成年\n";
} elsif ($age >= 18 && $age < 60) {
    print "成年\n";
} else {
    print "老年\n";
}

Perl 循环结构

Perl 支持 forforeachwhileuntil 循环。foreach 通常用于遍历数组。

perl 复制代码
for ($i = 0; $i < 5; $i++) {
    print "$i\n";
}

foreach $item (@array) {
    print "$item\n";
}

while ($count < 10) {
    print "$count\n";
    $count++;
}

Perl 子程序

子程序通过 sub 定义,参数通过 @_ 数组访问。返回值可以是标量或列表。

perl 复制代码
sub add {
    my ($a, $b) = @_;
    return $a + $b;
}

$result = add(3, 4);  # 返回 7

Perl 正则表达式

Perl 以强大的正则表达式著称。匹配操作符 =~ 和替换操作符 s/// 是常用工具。

perl 复制代码
$str = "Perl is great";
if ($str =~ /great/) {
    print "匹配成功\n";
}

$str =~ s/great/awesome/;  # 替换为 "Perl is awesome"

Perl 文件操作

文件操作通过文件句柄实现。open 用于打开文件,<> 用于读取,close 用于关闭。

perl 复制代码
open(FH, '<', "file.txt") or die "无法打开文件";
while (<FH>) {
    print $_;
}
close(FH);

Perl 特殊变量

Perl 有许多特殊变量,如 $_(默认变量)、@ARGV(命令行参数)和 $!(错误信息)。

perl 复制代码
foreach (@array) {
    print;  # 默认使用 $_
}

print "Error: $!\n" if !open(FH, '<', "file.txt");

Perl 模块使用

通过 use 加载模块,Exporter 是常用的模块接口工具。CPAN 是 Perl 的模块仓库。

perl 复制代码
use strict;    # 启用严格检查
use warnings;  # 启用警告
use Data::Dumper;  # 加载调试模块

Perl 引用与数据结构

引用用于创建复杂数据结构。反斜杠 \ 获取变量引用,解引用通过 $@% 前缀完成。

perl 复制代码
$array_ref = \@array;
$hash_ref = \%hash;

print $array_ref->[0];  # 访问数组引用元素
print $hash_ref->{"a"}; # 访问哈希引用值
相关推荐
KaMeidebaby5 小时前
卡梅德生物技术快报|纳米抗体表达:分子生物学实操指南:噬菌体筛选与纳米抗体表达全流程技术拆解
大数据·人工智能·架构·spark·新浪微博
Nefu_lyh13 小时前
【Hive】 八、Hive 计算引擎:MapReduce / Tez / Spark 对比与选型
hive·spark·mapreduce
RisunJan1 天前
Linux命令-perl (perl语言解释器)
linux·perl
极光代码工作室2 天前
基于数据分析的电影票房预测系统
大数据·python·数据分析·spark·数据可视化
KaMeidebaby2 天前
卡梅德生物技术快报|噬菌体文库构建实验优化及偶联体系实验数据分析
大数据·人工智能·架构·spark·新浪微博
鸿乃江边鸟2 天前
Spark中怎么做Spark canonicalize归一化
大数据·分布式·spark
李子琪。4 天前
谷歌“三剑客”与云计算基石:GFS、MapReduce、Bigtable 全栈解析及私有云落地实践
开发语言·编辑器·perl
ACP广源盛139246256734 天前
GSV2221 显示转换芯片@ACP#赋能 RTX Spark 端侧 AI 设备,构建多屏全模态视觉交互新生态
大数据·人工智能·嵌入式硬件·gpt·spark·电脑·音视频
李白的天不白4 天前
确认 Nginx 配置文件是否真的生效
scala
ACP广源盛139246256734 天前
GSV2231 三屏显示扩展芯片@ACP#RTX Spark AI 终端多屏协作专属解决方案
大数据·人工智能·分布式·信息可视化·spark·电脑·音视频