fen*_*ent 2 javascript algorithm
我正在尝试将匹配的字符串转换/(\d)+(\.\d+)?(m|g|t)?b?/i为字节.
例如,1KB将返回1024.1.2mb将返回1258291.
如果您重新组织正则表达式中的捕获组,那么:/(\d+(?:\.\d+)?)\s?(k|m|g|t)?b?/i
您可以执行以下操作:
function unhumanize(text) {
var powers = {'k': 1, 'm': 2, 'g': 3, 't': 4};
var regex = /(\d+(?:\.\d+)?)\s?(k|m|g|t)?b?/i;
var res = regex.exec(text);
return res[1] * Math.pow(1024, powers[res[2].toLowerCase()]);
}
unhumanize('1 Kb')
# 1024
unhumanize('1 Mb')
# 1048576
unhumanize('1 Gb')
# 1073741824
unhumanize('1 Tb')
# 1099511627776
Run Code Online (Sandbox Code Playgroud)