位置: 编程技术 - 正文

详解Python3中字符串中的数字提取方法(python中中文字符)

编辑:rootadmin

推荐整理分享详解Python3中字符串中的数字提取方法(python中中文字符),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python中中文字符,python3中文,python3.8.5中文,python3支持中文,python中中文字符,python3中文,python3.7中文,python中中文字符,内容如对您有帮助,希望把文章链接给更多的朋友!

逛到一个有意思的博客在里面看到一篇关于ValueError: invalid literal for int() with base 错误的解析,针对这个错误,博主已经给出解决办法,使用的是re.sub 方法

但是没有说明什么含义,于是去查了其他的资料,做一下记录:

在Python3.5.2 官方文档re模块中sub函数的定义是:

详解Python3中字符串中的数字提取方法(python中中文字符)

在字符串 string 中找到匹配正则表达式 pattern 的所有子串,用另一个字符串 repl 进行替换。如果没有找到匹配 pattern 的串,则返回未被修改的 string。Repl 既可以是字符串也可以是一个函数。

由此可分析上面使用的语句的含义:在'abc'这个字符串中找到非数字的字符(正则表达式中'D'表示非数字),并用""替换,然后返回的就是只剩下数字的字符串。

好吧,以上说明完毕,不过其实我想到的是我爬取知乎所关注的问答时,所遇到的类似的问题:

其中第三行之所以能用int(),是因为string.split()[0]将answer_num_get的值“ 个回答”提取出数字(注:后面有一个空格,在这里非常重要,因为知乎上抓取回来的这个元素就是)

split()的定义 str.split(sep=None, maxsplit=-1)

由此可看出split()的第一个参数是分隔符,如果什么都不填就是默认是以空格来分隔。

第一种方法需要用到正则表达式,第二种方法则需要有分隔符(我猜是不是这个原因,在原网页上总答案数的数字后有个空格存在)。 这两种方法都有点局限性,不知道是否有更好的方法来分离字符串中的数字。

本文链接地址:https://www.jiuchutong.com/biancheng/381394.html 转载请保留说明!

上一篇:win7上python2.7连接mysql数据库的方法(win7 python)

下一篇:Python科学计算之Pandas详解(python科学计算程序)

免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

鄂ICP备2023003026号

网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

友情链接: 武汉网站建设 电脑维修 湖南楚通运网络