我使用md5sum为文件生成哈希值。 但我只需要接收哈希值,而不是文件名。
md5=`md5sum ${my_iso_file}`
echo ${md5}
输出:
3abb17b66815bc7946cefe727737d295 ./iso/somefile.iso
我如何“剥离”文件名,只保留值?
我使用md5sum为文件生成哈希值。 但我只需要接收哈希值,而不是文件名。
md5=`md5sum ${my_iso_file}`
echo ${md5}
输出:
3abb17b66815bc7946cefe727737d295 ./iso/somefile.iso
我如何“剥离”文件名,只保留值?
md5="$(md5sum "${my_iso_file}")"
md5="${md5%% *}" # remove the first space and everything after it
echo "${md5}"
一个方法:
set -- $(md5sum $file)
md5=$1
另一种方法:
md5=$(md5sum $file | while read sum file; do echo $sum; done)
另一种方法:
md5=$(set -- $(md5sum $file); echo $1)
(不要尝试用反斜杠,除非你非常勇敢并且非常擅长反斜杠。)
这些解决方案相对于其他解决方案的优点是,它们只调用md5sum和shell,而不调用其他程序,如awk或sed。那么,这是否真的重要就另当别论了;你可能很难注意到其中的区别。
一个简单的数组赋值工作…请注意,Bash数组的第一个元素可以仅用名称寻址,而不带[0]索引,即$md5只包含md5sum的32个字符。
md5=($(md5sum file))
echo $md5
# 53c8fdfcbb60cf8e1a1ee90601cc8fe2
如果文件名中有反斜杠,Md5sum会在散列前加上一个反斜杠。前32个字符或第一个空格之前的任何字符可能不是正确的散列。
当使用标准输入时(文件名将只是-),它不会发生,所以pixelbeat的答案将工作,但许多其他将需要添加像| tail -c 32这样的东西。
好吧,我今天遇到了同样的问题,但是我在运行find命令时试图获得文件MD5哈希。
我得到了投票最多的问题,并将其包装在一个名为md5的函数中,以便在find命令中运行。我的任务是计算文件夹中所有文件的哈希值,并将其输出为hash:filename。
md5() { md5sum $1 | awk '{ printf "%s",$1 }'; }
export -f md5
find -type f -exec bash -c 'md5 "$0"' {} \; -exec echo -n ':' \; -print
所以,我从这里得到了一些片段,也从'find -exec'中得到了一个Linux中的shell函数
为了完整起见,sed使用正则表达式和捕获组的一种方法:
md5=$(md5sum "${my_iso_file}" | sed -r 's:\\*([^ ]*).*:\1:')
正则表达式捕获一个组中的所有内容,直到到达一个空格。要使捕获组工作,您需要捕获sed中的所有内容。
(关于sed和捕获组的更多信息请参见:如何使用sed只输出捕获的组?)
作为sed中的分隔符,我使用冒号,因为它们在文件路径中无效,而且我不必转义文件路径中的斜杠。
如果你担心文件名不正常:
md5sum < "${file_name}" | awk NF=1
f244e67ca3e71fff91cdf9b8bd3aa7a5
其他更混乱的处理方法:
md5sum "${file_name}" | awk NF=NF OFS= FS=' .*$' 或 | awk '_{exit}++_' RS=' '
f244e67ca3e71fff91cdf9b8bd3aa7a5
完全在awk中完成:
mawk '开始 { __ = ARGV[ --ARGC ] _ = sprintf(“%c”,(_+=(_^=_<_)+_)^_+_*++_) RS = FS gsub(_,“&\\\\&”,__) ( _=“ md5sum < ”((_)(__)_) ) |获取线 print $(_*close(_)) }' “${file_name}”
f244e67ca3e71fff91cdf9b8bd3aa7a5