如何用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只是一种示意,你可以按照具体业务逻辑调整返回值的处理方式)。
相关推荐
明月_清风5 小时前
Python 装饰器前传:如果不懂“闭包”,你只是在复刻代码
后端·python
明月_清风5 小时前
打破“死亡环联”:深挖 Python 分代回收与垃圾回收(GC)机制
后端·python
ZhengEnCi1 天前
08c. 检索算法与策略-混合检索
后端·python·算法
明月_清风1 天前
Python 内存手术刀:sys.getrefcount 与引用计数的生死时速
后端·python
明月_清风1 天前
Python 消失的内存:为什么 list=[] 是新手最容易踩的“毒苹果”?
后端·python
Flittly2 天前
【从零手写 ClaudeCode:learn-claude-code 项目实战笔记】(3)TodoWrite (待办写入)
python·agent
千寻girling2 天前
一份不可多得的 《 Django 》 零基础入门教程
后端·python·面试
databook2 天前
探索视觉的边界:用 Manim 重现有趣的知觉错觉
python·动效
明月_清风2 天前
Python 性能微观世界:列表推导式 vs for 循环
后端·python
明月_清风2 天前
Python 性能翻身仗:从 O(n) 到 O(1) 的工程实践
后端·python