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"}; # 访问哈希引用值
相关推荐
鸿乃江边鸟6 小时前
Spark Datafusion Comet 向量化Rule--CometScanRule分析
大数据·spark·native
浊酒南街6 小时前
spark sql 中LENGTH 和 SIZE 函数介绍
sql·spark
青云交6 小时前
Java 大视界 -- Java+Spark 构建离线数据仓库:分层设计与 ETL 开发实战(445)
java·数据仓库·spark·分层设计·java+spark·离线数据仓库·etl 开发
yumgpkpm1 天前
基于GPU的Spark应用加速 Cloudera CDP/华为CMP鲲鹏版+Nvidia英伟达联合解决方案
大数据·数据库·人工智能·hadoop·elasticsearch·spark·cloudera
鸿乃江边鸟1 天前
Spark Datafusion Comet 向量化--ApplyColumnarRulesAndInsertTransitions规则
大数据·spark·native
飞Link2 天前
【大数据】SparkSQL常用操作
大数据·数据挖掘·spark
浊酒南街2 天前
SUBSTRING_INDEX 函数介绍
sql·spark
鸿乃江边鸟2 天前
Spark datafusion comet向量化插件CometPlugin
大数据·spark·native
oMcLin2 天前
如何在 Debian 11 上通过构建大数据湖,使用 Apache Spark 加速电商平台的数据分析与实时推荐引擎
spark·debian·apache