加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

在Perl中获取文件校验和的紧凑方式

发布时间:2020-12-15 21:58:03 所属栏目:大数据 来源:网络整理
导读:我正在寻找在Perl中获取文件校验和的方法,但不是通过执行系统命令cksum – 想在Perl本身中执行它,因为脚本需要在UNIX和 Windows之间移植. cksum FILENAME | awk'{print $1}’适用于UNIX,但显然不适用于Windows.我已经探索了 MD5,但看起来像获取文件句柄似乎
我正在寻找在Perl中获取文件校验和的方法,但不是通过执行系统命令cksum – 想在Perl本身中执行它,因为脚本需要在UNIX和 Windows之间移植. cksum< FILENAME> | awk'{print $1}’适用于UNIX,但显然不适用于Windows.我已经探索了 MD5,但看起来像获取文件句柄似乎是必要的,并且通常它似乎不是一种非常紧凑的方式来获取该数据(一线优选).

有没有更好的办法?

解决方法

根据您提供的模块,有三种不同的方式:
use Digest::MD5 qw(md5_hex);

use File::Slurp;
print md5_hex(read_file("filename")),"n";

use IO::All;
print md5_hex(io("filename")->all),"n";

use IO::File;
print md5_hex(do { local $/; IO::File->new("filename")->getline }),"n";

不是完全一线但非常接近.

将Digest :: MD5替换为您想要的任何哈希算法,例如: SHA1.

IO :: File是核心,应该随处可用,但这是我个人最不喜欢的解决方案.无论如何,它的工作原理.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读