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

作者:Lucystone 时间:2021-02-22 06:08:15 

逛到一个有意思的博客在里面看到一篇关于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()的第一个参数是分隔符,如果什么都不填就是默认是以空格来分隔。

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

来源:http://www.cnblogs.com/Lucystonenix/p/5929931.html

标签:python,字符串,提取,数字
0
投稿

猜你喜欢

  • Python进阶-函数默认参数(详解)

    2023-11-16 17:14:44
  • Python超简单容易上手的画图工具库(适合新手)

    2021-12-06 04:05:23
  • 常见系统中文字体的英文名

    2008-03-03 12:44:00
  • SQL Server数据库管理常用SQL和T-SQL语句

    2009-05-07 14:01:00
  • 基于php socket(fsockopen)的应用实例分析

    2023-11-18 21:38:32
  • ORACLE常用数值函数、转换函数、字符串函数

    2023-07-21 02:03:40
  • PyTorch预训练Bert模型的示例

    2021-11-12 14:31:39
  • MySQL内建复制功能来优化可用性

    2010-10-25 20:20:00
  • 用ASP打造一个小型的网页BBS系统

    2008-10-10 16:36:00
  • 验证码-挑战你的智慧

    2008-09-10 13:08:00
  • 什么是响应式Web设计?怎样进行?

    2011-11-21 17:00:40
  • python+tifffile之tiff文件读写方式

    2022-03-16 13:17:41
  • python实现SMTP邮件发送功能

    2023-11-11 08:04:03
  • ORACLE 常用函数总结(80个)第1/2页

    2009-09-18 13:23:00
  • Python Tkinter基础控件用法

    2023-04-11 18:35:14
  • asp清理缓存的代码

    2011-03-09 11:16:00
  • 使用Python将数组的元素导出到变量中(unpacking)

    2022-01-12 10:11:43
  • Go语言中的Array、Slice、Map和Set使用详解

    2023-06-24 07:29:03
  • 解析SQL Server 2008中的新语句:MERGE

    2009-01-13 13:57:00
  • 使用python进行nc转tif的3种情况解决

    2022-05-09 11:22:43
  • asp之家 网络编程 m.aspxhome.com