
代码解释:
- 导入 re 库: import re 导入正则表达式库,用于模式匹配。
- 循环输入: while run: 循环接收用户输入。
- 检查命令: if "-mp" in func: 检查输入字符串是否包含 -mp 命令。
- 分割字符串: que = func.split(" ") 使用空格作为分隔符,将输入字符串分割成一个列表。例如,输入 "-mp 1A -10 -15 18 20" 会被分割成 que = ['-mp', '1A', '-10', '-15', '18', '20']。
- 遍历列表: for i in que: 遍历分割后的列表。
-
过滤非数字元素: if not re.search(r'[a-zA-Z. ]', i) and i != '-mp': 这是核心逻辑。
- re.search(r'[a-zA-Z. ]', i) 检查当前元素 i 是否包含字母、点号或空格。如果包含,则返回一个匹配对象,否则返回 None。
- not re.search(...) 对匹配结果取反,即只有当元素 i 不包含字母、点号或空格时,条件才成立。
- i != '-mp' 确保当前元素不是命令 -mp。
- 输出数字: print(i) 如果当前元素满足条件(即只包含数字),则输出该元素。
示例:
如果用户输入 "-mp 1A -10 -15 18 20",程序将输出:
-10 -15 18 20
注意事项:
- re.search(r'[a-zA-Z. ]', i) 中的正则表达式 r'[a-zA-Z. ]' 用于匹配任何字母(大小写)、点号和空格。可以根据实际需求修改正则表达式,以匹配其他不需要的字符。
- 这种方法假设数字之间使用空格分隔。如果分隔符不同,需要相应地修改 func.split(" ") 中的参数。
- 如果需要将提取的字符串转换为数字类型(例如 int 或 float),可以使用 int(i) 或 float(i) 进行转换。需要注意处理可能出现的 ValueError 异常。
总结
通过使用 re 库和字符串分割方法,我们可以更灵活地从字符串中提取数字,即使参数顺序不固定或者包含非数字字符也能正确解析。这种方法比简单的字符串切片更通用,适用于更复杂的情况。在实际应用中,可以根据具体需求调整正则表达式和分隔符,以满足不同的要求。
立即学习“Python免费学习笔记(深入)”;










