如何用re从第1排第2个位置中找到两个数字返回(0,1)

以下是使用 Python 的re模块从第1班第2个位置这样的字符串中提取出数字并返回类似(0, 1)这种形式的示例代码,假设数字都是一位数的情况(如果是多位数可以按照后续介绍稍作调整):

复制代码
import re


def extract_numbers(text):
    numbers = re.findall(r'\d', text)
    if len(numbers) >= 2:
        return int(numbers[0]) - 1, int(numbers[1]) - 1
    return None  # 如果没找到两个数字可以根据需求返回合适的值,这里返回None示意


text = "第1班第2个位置"
result = extract_numbers(text)
print(result)

在上述代码中:

  1. 首先定义了函数extract_numbers,它接收一个字符串参数text
  2. 在函数内部,使用re.findall(r'\d', text)来查找字符串中所有的数字字符,将找到的数字以列表形式存储在numbers变量中。
  3. 接着判断numbers列表的长度是否大于等于 2,如果是,就将提取到的第一个数字(索引为 0)和第二个数字(索引为 1)分别转换为整数(并且做了减 1 的操作以符合返回类似索引从 0 开始的(0, 1)这种效果,你可以根据实际需求决定是否减 1 等处理),然后以元组形式返回。
  4. 如果提取的数字不足两个,就返回None(这里返回None只是一种示意,你可以按照具体业务逻辑调整返回值的处理方式)。
相关推荐
花米徐4 小时前
技术洞察精选 | 2026年4月28日 — 5月4日
后端·python·flask
宝贝儿好4 小时前
【LLM】第三章:项目实操案例:智能输入法项目
人工智能·python·深度学习·算法·机器人
m0_624578594 小时前
如何在phpMyAdmin中导入GZIP压缩格式文件_加速传输并突破文件大小限制
jvm·数据库·python
m0_495496414 小时前
mysql数据库表名区分大小写吗_通过lower case table names配置
jvm·数据库·python
weixin_459753945 小时前
MySQL主从同步跳过错误影响一致性_使用pt-table-sync修复
jvm·数据库·python
kexnjdcncnxjs5 小时前
如何解决Oracle 12c以上版本的ORA-65096_C##公共用户前缀限制
jvm·数据库·python
zhoutongsheng5 小时前
MySQL触发器无法触发的原因分析_MySQL触发器排查指南
jvm·数据库·python
夏沫琅琊5 小时前
基于python 的日志文件分析器
python
财经资讯数据_灵砚智能5 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(夜间-次晨)2026年5月10日
大数据·人工智能·python·信息可视化·自然语言处理