逛到一个有意思的博客在里面看到一篇关于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中从字符串中提取部分内容
# 的是
# 种方法
# 正则表达式
# 是一个
# 分隔符
# 在这里
# 是因为
# 有个
# 中找到
# 第一个
# 要有
# 其他的
# 如果没有
# 好吧
# 只剩下
# 在里面
# 非常重要
# 既可
# 我猜
# 这两种
相关文章:
定制建站流程解析:需求评估与SEO优化功能开发指南
公众号网站制作网页,微信公众号怎么制作?
建站之星安装提示数据库无法连接如何解决?
广平建站公司哪家专业可靠?如何选择?
如何快速启动建站代理加盟业务?
七夕网站制作视频,七夕大促活动怎么报名?
购物网站制作公司有哪些,哪个购物网站比较好?
Bpmn 2.0的XML文件怎么画流程图
网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?
SQL查询语句优化的实用方法总结
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
公司网站制作费用多少,为公司建立一个网站需要哪些费用?
宝塔建站后网页无法访问如何解决?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
建站主机核心功能解析:服务器选择与网站搭建流程指南
如何快速查询网址的建站时间与历史轨迹?
如何通过PHP快速构建高效问答网站功能?
杭州银行网站设计制作流程,杭州银行怎么开通认证方式?
如何在云主机上快速搭建多站点网站?
开心动漫网站制作软件下载,十分开心动画为何停播?
建站主机解析:虚拟主机配置与服务器选择指南
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何快速搭建自助建站会员专属系统?
如何选择网络建站服务器?高效建站必看指南
哈尔滨网站建设策划,哈尔滨电工证查询网站?
武清网站制作公司,天津武清个人营业执照注销查询系统网站?
实惠建站价格推荐:2025年高性价比自助建站套餐解析
实例解析angularjs的filter过滤器
网站设计制作企业有哪些,抖音官网主页怎么设置?
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
设计网站制作公司有哪些,制作网页教程?
如何做网站制作流程,*游戏网站怎么搭建?
免费视频制作网站,更新又快又好的免费电影网站?
宝塔新建站点为何无法访问?如何排查?
制作网站怎么制作,*游戏网站怎么搭建?
如何配置支付宝与微信支付功能?
C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换
如何用5美元大硬盘VPS安全高效搭建个人网站?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
创业网站制作流程,创业网站可靠吗?
制作宣传网站的软件,小红书可以宣传网站吗?
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
如何在IIS7上新建站点并设置安全权限?
建站之星×万网:智能建站系统+自助建站平台一键生成
简单实现Android文件上传
制作农业网站的软件,比较好的农业网站推荐一下?
如何获取PHP WAP自助建站系统源码?
,想在网上投简历,哪几个网站比较好?
*请认真填写需求信息,我们会在24小时内与您取得联系。