逛到一个有意思的博客在里面看到一篇关于ValueError: invalid literal for int() with base 10错误的解析,针对这个错误,博主已经给出解决办法,使用的是re.sub 方法
totalCount = '100abc'
totalCount = re.sub("\D", "", totalCount)
但是没有说明什么含义,于是去查了其他的资料,做一下记录:
在Python3.5.2 官方文档re模块中sub函数的定义是:
re.sub(pattern, repl, string, count=0, flags=0)
在字符串 string 中找到匹配正则表达式 pattern 的所有子串,用另一个字符串 repl 进行替换。如果没有找到匹配 pattern 的串,则返回未被修改的 string。Repl 既可以是字符串也可以是一个函数。
由此可分析上面使用的语句的含义:在'100abc'这个字符串中找到非数字的字符(正则表达式中'\D'表示非数字),并用""替换,然后返回的就是只剩下数字的字符串。
>>> totalCount = '100abc'
>>> totalCount = re.sub("\D", "", totalCount)
>>> print(totalCount)
100
>>> type(totalCount)
<class 'str'>
好吧,以上说明完毕,不过其实我想到的是我爬取知乎所关注的问答时,所遇到的类似的问题:
answer_num_get = soup.find('h3', {'id': 'zh-question-answer-num'}) # 答案数量:32 个回答
if answer_num_get is not None:
answer_num = int(answer_num_get.split()[0])
n = answer_num // 10
其中第三行之所以能用int(),是因为string.split()[0]将answer_num_get的值“32 个回答”提取出数字(注:32后面有一个空格,在这里非常重要,因为知乎上抓取回来的这个元素就是)
split()的定义 str.split(sep=None, maxsplit=-1)
>>> import string
>>> a = "32 个答案"
>>> b = a.split()[0]
>>> print(b)
32
>>> type(b)
<class 'str'>
>>> c = '1,2,3'
>>> c.split(',')
['1', '2', '3']
>>> c.split(',')[0]
'1'
>>> c.split(',')[1]
'2'
>>>
由此可看出split()的第一个参数是分隔符,如果什么都不填就是默认是以空格来分隔。
第一种方法需要用到正则表达式,第二种方法则需要有分隔符(我猜是不是这个原因,在原网页上总答案数的数字后有个空格存在)。 这两种方法都有点局限性,不知道是否有更好的方法来分离字符串中的数字。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# python字符串提取数字
# python
# 字符串提取
# python提取字符串数字
# python利用正则表达式提取字符串
# 如何利用python提取字符串中的数字
# 使用Python提取文本中含有特定字符串的方法示例
# python提取具有某种特定字符串的行数据方法
# Python利用正则表达式从字符串提取数字
# 如何使用python提取字符串的中英文(正则判断)
# 一文详解如何使用Python从字符串中提取数字
# python如何用正则表达式提取字符串
# 一文详解如何在Python中从字符串中提取部分内容
# 的是
# 种方法
# 正则表达式
# 是一个
# 分隔符
# 在这里
# 是因为
# 有个
# 中找到
# 第一个
# 要有
# 其他的
# 如果没有
# 好吧
# 只剩下
# 在里面
# 非常重要
# 既可
# 我猜
# 这两种
相关文章:
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
建站主机如何选?性能与价格怎样平衡?
代刷网站制作软件,别人代刷火车票靠谱吗?
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
济南专业网站制作公司,济南信息工程学校怎么样?
如何实现建站之星域名转发设置?
如何基于云服务器快速搭建网站及云盘系统?
昆明高端网站制作公司,昆明公租房申请网上登录入口?
,想在网上投简历,哪几个网站比较好?
如何用免费手机建站系统零基础打造专业网站?
实现虚拟支付需哪些建站技术支撑?
建站之星导航如何优化提升用户体验?
如何使用Golang安装API文档生成工具_快速生成接口文档
如何通过免费商城建站系统源码自定义网站主题与功能?
建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析
保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?
视频网站制作教程,怎么样制作优酷网的小视频?
如何用景安虚拟主机手机版绑定域名建站?
建站之星24小时客服电话如何获取?
历史网站制作软件,华为如何找回被删除的网站?
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
如何在阿里云域名上完成建站全流程?
建站主机系统SEO优化与智能配置核心关键词操作指南
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
详解jQuery停止动画——stop()方法的使用
常州自助建站:操作简便模板丰富,企业个人快速搭建网站
矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?
电商网站制作公司有哪些,1688网是什么意思?
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
香港服务器部署网站为何提示未备案?
如何零成本快速生成个人自助网站?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
如何在自有机房高效搭建专业网站?
建站之星如何开启自定义404页面避免用户流失?
建站之星安装路径如何正确选择及配置?
C++如何使用std::optional?(处理可选值)
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
建站之星logo尺寸如何设置最合适?
建站之星如何快速解决建站难题?
如何快速查询网站的真实建站时间?
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
如何制作算命网站,怎么注册算命网站?
早安海报制作网站推荐大全,企业早安海报怎么每天更换?
如何批量查询域名的建站时间记录?
SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?
制作网站的公司有哪些,做一个公司网站要多少钱?
如何通过FTP空间快速搭建安全高效网站?
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
*请认真填写需求信息,我们会在24小时内与您取得联系。