我有一个包含十进制数字的文本文件,并希望将任何具有小数> = 0.5
的数据四舍五入,否则我想截断小数,例如,23.7897
变为{ {1}}和24
变为17.2395
。
<对于17
0.5
案例不是问题
re.sub
然而,对于> = re.sub(r'(\d+)\.[0-4]\d*', r'\1', line)
的情况,我想知道是否有办法在替换过程中以某种方式操纵0.5
捕获组?它是否存储在任何地方,以便可以发送到函数,例如:
\1
其中re.sub(r'(\d+)\.[5-9]\d*', roundUp('\1'), line)
返回表示值roundUp()
的字符串。
当然有一种方法可以在替换期间只增加\1 + 1
内联,而不必循环来自\1
的匹配,递增整数部分,然后使用findall
重新绘制模式并将其替换掉在?
答案 0 :(得分:2)
你可以使用任意的callable进行替换,这对你有用吗?
re.sub(r'\d+\.\d*', lambda match: str(int(round(float(match.group(0))))), line)