标题确实说明了一切,但我目前正在使用一个带有 case 语句的简单函数将人类可读的文件大小字符串转换为以字节为单位的大小。它工作得很好,但是对于移植到其他代码来说有点笨拙,所以我很想知道是否有任何广泛可用的命令可供 shell 脚本使用?
基本上我想获取诸如“100g”或“100gb”之类的字符串并将它们转换为字节。
我目前正在执行以下操作:
to_bytes() {
value=$(echo "$1" | sed 's/[^0123456789].*$//g')
units=$(echo "$1" | sed 's/^[0123456789]*//g' | tr '[:upper:]' '[:lower:]')
case "$units" in
t|tb) let 'value *= 1024 * 1024 * 1024 * 1024' ;;
g|gb) let 'value *= 1024 * 1024 * 1024' ;;
m|mb) let 'value *= 1024 * 1024' ;;
k|kb) let 'value *= 1024' ;;
b|'') let 'value += 0' ;;
*)
value=
echo "Unsupported units '$units'" >&2
;;
esac
echo "$value"
}
对于我认为对于处理文件的脚本来说相当普遍的东西来说,这似乎有点矫枉过正;足够普遍,以至于可能存在一些东西可以更快地做到这一点。
如果没有广泛可用的解决方案(即大多数 unix 和 linux 风格),那么我仍然会感谢任何优化上述功能的技巧,因为我想让它更小更容易重用。