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"}; # 访问哈希引用值
相关推荐
历程里程碑18 小时前
链表-----
数据结构·线性代数·算法·链表·矩阵·lua·perl
D愿你归来仍是少年1 天前
Apache Spark 第 3 章:核心概念 RDD / DataFrame
大数据·spark·apache
Hello.Reader1 天前
PySpark 安装保姆级教程pip、Conda、手动安装、Spark Connect 一次讲透(一)
python·spark·conda·pip
Light601 天前
SPARK Agent Protocol(SAP):AI Agent时代的前端开发革命指南
大数据·人工智能·spark
D愿你归来仍是少年1 天前
Apache Spark 第 4 章:Spark 整体架构
spark·apache
datablau国产数据库建模工具1 天前
【无标题】
大数据·数据挖掘·spark
yumgpkpm1 天前
Apache Spark 和 Flink,处理实时大数据流对比(Cloudera CDH、CDP)
flink·spark·apache
D愿你归来仍是少年2 天前
Apache Spark 从入门到精通:完整学习指南
大数据·spark
D愿你归来仍是少年2 天前
Apache Spark Real-Time Mode 深度解析:打破微批次壁垒,挑战 Flink 的实时王座
flink·spark·apache
jerryinwuhan2 天前
Spark 安装配置1
大数据·分布式·spark