详解Python3中字符串中的数字提取方法

发布时间 - 2026-01-10 22:31:56    点击率:

逛到一个有意思的博客在里面看到一篇关于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中从字符串中提取部分内容  # 的是  # 种方法  # 正则表达式  # 是一个  # 分隔符  # 在这里  # 是因为  # 有个  # 中找到  # 第一个  # 要有  # 其他的  # 如果没有  # 好吧  # 只剩下  # 在里面  # 非常重要  # 既可  # 我猜  # 这两种 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复  如何有效防御Web建站篡改攻击?  如何快速搭建高效服务器建站系统?  iOS中将个别页面强制横屏其他页面竖屏  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理  Laravel怎么连接多个数据库_Laravel多数据库连接配置  Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何在云主机上快速搭建多站点网站?  如何快速搭建安全的FTP站点?  ,网页ppt怎么弄成自己的ppt?  在centOS 7安装mysql 5.7的详细教程  Laravel观察者模式如何使用_Laravel Model Observer配置  高防服务器如何保障网站安全无虞?  郑州企业网站制作公司,郑州招聘网站有哪些?  php结合redis实现高并发下的抢购、秒杀功能的实例  动图在线制作网站有哪些,滑动动图图集怎么做?  如何在IIS中配置站点IP、端口及主机头?  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  Laravel如何配置Horizon来管理队列?(安装和使用)  JS碰撞运动实现方法详解  如何自定义建站之星网站的导航菜单样式?  ,南京靠谱的征婚网站?  javascript如何操作浏览器历史记录_怎样实现无刷新导航  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  智能起名网站制作软件有哪些,制作logo的软件?  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  Claude怎样写约束型提示词_Claude约束提示词写法【教程】  香港服务器租用每月最低只需15元?  Laravel如何使用查询构建器?(Query Builder高级用法)  高性价比服务器租赁——企业级配置与24小时运维服务  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  jQuery中的100个技巧汇总  Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  如何在IIS7中新建站点?详细步骤解析  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  如何批量查询域名的建站时间记录?  如何快速生成专业多端适配建站电话?  如何为不同团队 ID 动态生成多个“认领值班”按钮  Laravel如何实现密码重置功能_Laravel密码找回与重置流程  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  如何在VPS电脑上快速搭建网站?  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  HTML 中如何正确使用模板变量为元素的 name 属性赋值  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  如何挑选高效建站主机与优质域名?  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】