【perl】老司机的再一次翻车:没有想到加了一句打印,会影响结果输出

简介: 【perl】老司机的再一次翻车:没有想到加了一句打印,会影响结果输出

前言

自诩为多年perl海浮沉的老司机,竟然因为加了一句打印而翻车,这真是万万没有想到,记录一下引以为戒。

事情的由来

在脚本的读取文件里有很多字符串进行处理的时候,定位就会变得困难,比如说我只想打印A的沿路信息,但是直接加打印就会把ABCDE的一大堆信息全打印出来,筛选起来非常的难受。

因此我想到了之前搭环境时候做的一个操作,做一个debug函数在数据流里筛选,符合我需求的(比如说带有ecc error的transaction)报文才会触发debug打印,这种操作在脚本里完全可以照搬一下嘛!

额外感叹一下,最近越来越感觉到我做脚本的思路继承了各种之前搭环境的思路,估计没有几个人写perl的时候还要设置打印等级和最大error数量吧🆒

回归原题,因此我就做了一个简单的筛选机制,简化下的意思就是这样:

my $debug_name = “AA”;
warn “xxxxx” if $name =~ /$debug_name/;
• 1
• 2
• 3

也很好理解嘛,某一个变量包含我需要的信息,那就打印一些debug信息给我,如果不包含就pass,写完后我就觉得简直天衣无缝。

翻车事故

我一直这么开心的用着,直到一次我发现,某一处我加了打印后,竟然输出结果跟不加打印完全不一样?!当时我都疯了,倒是见过加一句$display把随机搞乱的情况,脚本里我还真的没见过加打印能影响输出的。

因此仔细的看了下上下文,终于发现了端倪,因为我的代码结构是这样子的:

if($name =~ /…/){
    warn “…” if $name =~ /$debug_name/;
    my $pre = $`;
    my $post = $’;
    my $body = $&;
}
• 1
• 2
• 3
• 4
• 5
• 6
• 7

问题就出现在下面的取匹配信息上了,本来我要取的是首行if里的匹配结果,结果这样一搞,我取到的是warn行后面的匹配结果,再加上我这里没有使用$1 $2编译没能报错,导致整个匹配处理彻底乱了也没被发现,最终的输出自然各种奇怪的东西。

问题解决

我把打印删了,改用eq ne,嘿高精度打印不搞模糊打印了~~~


相关文章
|
SQL 分布式计算 关系型数据库
Hadoop-13-Hive 启动Hive 修改启动参数命令行启动测试 几句简单的HQL了解Hive
Hadoop-13-Hive 启动Hive 修改启动参数命令行启动测试 几句简单的HQL了解Hive
310 2
|
数据采集 安全 Java
Burpsuite Intruder 暴力破jie实战
Burpsuite Intruder 暴力破jie实战
|
机器学习/深度学习 存储 计算机视觉
基于YOLOv8深度学习的200种鸟类智能检测与识别系统【python源码+Pyqt5界面+数据集+训练代码】目标检测、深度学习实战
基于YOLOv8深度学习的200种鸟类智能检测与识别系统【python源码+Pyqt5界面+数据集+训练代码】目标检测、深度学习实战
|
小程序 前端开发
【微信小程序-原生开发】TDesign 实战模板——聊天气泡
【微信小程序-原生开发】TDesign 实战模板——聊天气泡
370 0
|
消息中间件 NoSQL Java
Spring Boot中使用Redis和Lua脚本实现延时队列
Spring Boot中使用Redis和Lua脚本实现延时队列
|
自然语言处理 Java
ElasticSearch 实现分词全文检索 - match、match_all、multimatch查询
ElasticSearch 实现分词全文检索 - match、match_all、multimatch查询
1245 0
|
文字识别 Java 开发工具
印刷文字识别操作报错合集之遇到错误代码为401,该怎么办
在使用印刷文字识别(OCR)服务时,可能会遇到各种错误。例如:1.Java异常、2.配置文件错误、3.服务未开通、4.HTTP错误码、5.权限问题(403 Forbidden)、6.调用拒绝(Refused)、7.智能纠错问题、8.图片质量或格式问题,以下是一些常见错误及其可能的原因和解决方案的合集。
|
云安全 机器学习/深度学习 监控
降低运营成本:采用安全托管服务(Managed Security Service,MSS)
采用安全托管服务(MSS)能够减轻企业安全管理负担并节省成本,通过专业团队全天候监控与管理,有效提升安全防护水平且减少内部资源投入。
691 0
|
SQL JavaScript 前端开发
大数据 ETL 处理工具 Kettle 完成一个作业任务
简单一句话,作业流程,即是对转换流程进行调度,也可以嵌套转换流程和作业流程。