37 - 用正则表达式格式化字符串中所有的浮点数

举报
ruochen 发表于 2021/03/26 22:50:58 2021/03/26
【摘要】 用正则表达式查找字符串中所有的浮点数,并格式化这些浮点数,保留小数点后两位,最将格式化后的浮点数替换原来的浮点数,同时输出替换后的结果和替换的次数。要求用一条语句实现 import re ''' 1. 表示浮点数的正则表达式 -?\d+(\.\d+)? 2. 格式化浮点数 format 3. 如何替换原来的浮点数 sub: 只返回结果 subn: 返回一个元组 元组...

用正则表达式查找字符串中所有的浮点数,并格式化这些浮点数,保留小数点后两位,最将格式化后的浮点数替换原来的浮点数,同时输出替换后的结果和替换的次数。要求用一条语句实现

import re

'''
1. 表示浮点数的正则表达式 -?\d+(\.\d+)?
2. 格式化浮点数 format
3. 如何替换原来的浮点数 sub: 只返回结果 subn: 返回一个元组 元组第一个元素返回替换后的结果,第二个元素返回替换的次数
'''

result = re.subn('-?\d+(\.\d+)?', '##', 'PI is 3.14, e is 2.71, 1 + 1 = 2')
print(result)
print(result[0])
print(result[1])

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
('PI is ##, e is ##, ## + ## = ##', 5)
PI is ##, e is ##, ## + ## = ##
5

  
 
  • 1
  • 2
  • 3
def fun(matched): return '<' + matched.group() + '>'


result = re.subn('-?\d+(\.\d+)?', fun, 'PI is 3.14, e is 2.71, 1 + 1 = 2')
print(result)
print(result[0])
print(result[1])

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
('PI is <3.14>, e is <2.71>, <1> + <1> = <2>', 5)
PI is <3.14>, e is <2.71>, <1> + <1> = <2>
5

  
 
  • 1
  • 2
  • 3
def fun(matched): return format(float(matched.group()), '.1f')


result = re.subn('-?\d+(\.\d+)?', fun, 'PI is 3.14, e is 2.71, 1 + 1 = 2')
print(result)
print(result[0])
print(result[1])

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
('PI is 3.1, e is 2.7, 1.0 + 1.0 = 2.0', 5)
PI is 3.1, e is 2.7, 1.0 + 1.0 = 2.0
5

  
 
  • 1
  • 2
  • 3

38 - 提取HTML页面中的URL

文章来源: ruochen.blog.csdn.net,作者:若尘,版权归原作者所有,如需转载,请联系作者。

原文链接:ruochen.blog.csdn.net/article/details/104527157

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。