正则表达式搜索以从字符串中提取浮点数.Python

Regex search to extract float from string. Python(正则表达式搜索以从字符串中提取浮点数.Python)
本文介绍了正则表达式搜索以从字符串中提取浮点数.Python的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

import re

sequence = 'i have -0.03 dollars in my hand'

m = re.search('(have )(-w[.]+)( dollarsw+)',sequence)

print m.group(0)
print m.group(1)
print m.group(2)

Looking for a way to extract text between two occurrences. In this case, the format is 'i have ' followed by - floats and then followed by ' dollarsw+'

How do i use re.search to extract this float ? Why don't the groups work this way ? I know there's something I can tweak to get it to work with these groups. any help would be greatly appreciated

I thought I could use groups with paranthesis but i got an eror

解决方案

-w[.]+ does not match -0.03 because [.] matches . literally because . is inside the [...].

w after dollars also prevent the pattern to match the sequence. There no word character after dollars.

Use (-?d+.d+) as pattern:

import re

sequence = 'i have -0.03 dollars in my hand'

m = re.search(r'(have )(-?d+.d+)( dollars)', sequence)

print m.group(1) # captured group start from `1`.
print m.group(2) 
print m.group(3)

BTW, captured group numbers start from 1. (group(0) returns entire matched string)

这篇关于正则表达式搜索以从字符串中提取浮点数.Python的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)