在Python中获取括号内的字符串

发布于 2024-12-22 12:24:00 字数 372 浏览 1 评论 0原文

我有一个示例字符串 ,created=1324336085,description='Customer for My Test App',livemode=False>

我只想要值 cus_Y4o9qMEZAugtnW 而不是card(位于另一个[]内部)

我怎样才能在Python中以最简单的方式做到这一点? 也许通过使用正则表达式(我不擅长)?

I have a sample string <alpha.Customer[cus_Y4o9qMEZAugtnW] active_card=<alpha.AlphaObject[card] ...>, created=1324336085, description='Customer for My Test App', livemode=False>

I only want the value cus_Y4o9qMEZAugtnW and NOT card (which is inside another [])

How could I do it in easiest possible way in Python?
Maybe by using RegEx (which I am not good at)?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(8

高速公鹿 2024-12-29 12:24:00

怎么样:

import re

s = "alpha.Customer[cus_Y4o9qMEZAugtnW] ..."
m = re.search(r"\[([A-Za-z0-9_]+)\]", s)
print m.group(1)

对我来说,打印:

cus_Y4o9qMEZAugtnW

请注意,对 re.search(...) 的调用找到了正则表达式的第一个匹配项,因此它找不到 [card]除非您第二次重复搜索。

编辑:这里的正则表达式是一个python 原始字符串文字,这基本上意味着反斜杠不被视为特殊字符并被传递到 re.search( ) 方法不变。正则表达式的 部分 为:

  1. \[ 匹配文字 [ 字符
  2. ( 开始一个新组
  3. [A-Za-z0-9_] 是匹配任何字母(大写或小写字母)的字符集大小写)、数字或下划线
  4. + 匹配前面的元素(字符集)
  5. ) 结束组
  6. \] 与文字 ] 字符

编辑: 正如 DK 所指出的,正则表达式可以简化为:

m = re.search(r"\[(\w+)\]", s)

因为 \w 是一个特殊的序列,其含义与 [a-zA-Z0-9_ ] 取决于 re.LOCALEre.UNICODE 设置。

How about:

import re

s = "alpha.Customer[cus_Y4o9qMEZAugtnW] ..."
m = re.search(r"\[([A-Za-z0-9_]+)\]", s)
print m.group(1)

For me this prints:

cus_Y4o9qMEZAugtnW

Note that the call to re.search(...) finds the first match to the regular expression, so it doesn't find the [card] unless you repeat the search a second time.

Edit: The regular expression here is a python raw string literal, which basically means the backslashes are not treated as special characters and are passed through to the re.search() method unchanged. The parts of the regular expression are:

  1. \[ matches a literal [ character
  2. ( begins a new group
  3. [A-Za-z0-9_] is a character set matching any letter (capital or lower case), digit or underscore
  4. + matches the preceding element (the character set) one or more times.
  5. ) ends the group
  6. \] matches a literal ] character

Edit: As D K has pointed out, the regular expression could be simplified to:

m = re.search(r"\[(\w+)\]", s)

since the \w is a special sequence which means the same thing as [a-zA-Z0-9_] depending on the re.LOCALE and re.UNICODE settings.

涫野音 2024-12-29 12:24:00

您可以使用 str.split 来做这。

s = "<alpha.Customer[cus_Y4o9qMEZAugtnW] active_card=<alpha.AlphaObject[card]\
 ...>, created=1324336085, description='Customer for My Test App',\
 livemode=False>"
val = s.split('[', 1)[1].split(']')[0]

然后我们有:

>>> val
'cus_Y4o9qMEZAugtnW'

You could use str.split to do this.

s = "<alpha.Customer[cus_Y4o9qMEZAugtnW] active_card=<alpha.AlphaObject[card]\
 ...>, created=1324336085, description='Customer for My Test App',\
 livemode=False>"
val = s.split('[', 1)[1].split(']')[0]

Then we have:

>>> val
'cus_Y4o9qMEZAugtnW'
晌融 2024-12-29 12:24:00

这应该可以完成这项工作:

re.match(r"[^[]*\[([^]]*)\]", yourstring).groups()[0]

This should do the job:

re.match(r"[^[]*\[([^]]*)\]", yourstring).groups()[0]
贪恋 2024-12-29 12:24:00
your_string = "lnfgbdgfi343456dsfidf[my data] ljfbgns47647jfbgfjbgskj"
your_string[your_string.find("[")+1 : your_string.find("]")]

礼貌: 返回括号之间文本的正则表达式

your_string = "lnfgbdgfi343456dsfidf[my data] ljfbgns47647jfbgfjbgskj"
your_string[your_string.find("[")+1 : your_string.find("]")]

courtesy: Regular expression to return text between parenthesis

墨小墨 2024-12-29 12:24:00

也可以使用

re.findall(r"\[([A-Za-z0-9_]+)\]", string)

如果您想查找很多出现的情况,

。另请参阅了解更多信息:
如何找到 a 的所有匹配项Python 中的正则表达式?

You can also use

re.findall(r"\[([A-Za-z0-9_]+)\]", string)

if there are many occurrences that you would like to find.

See also for more info:
How can I find all matches to a regular expression in Python?

夏末染殇 2024-12-29 12:24:00

您可以使用

import re

s = re.search(r"\[.*?]", string)
if s:
    print(s.group(0))

You can use

import re

s = re.search(r"\[.*?]", string)
if s:
    print(s.group(0))
贪恋 2024-12-29 12:24:00

这个怎么样?使用文件说明的示例:

f = open('abc.log','r')
content = f.readlines()
for line in content:
    m = re.search(r"\[(.*?)\]", line)
    print m.group(1)
    

希望这有帮助:

Magic regex : \[(.*?)\]

解释:

\[[ 是一个元字符,如果您想按字面匹配它,则需要对其进行转义。

(.*?) :以非贪婪的方式匹配所有内容并捕获它。

\]] 是一个元字符,如果您想按字面匹配它,则需要对其进行转义。

How about this ? Example illusrated using a file:

f = open('abc.log','r')
content = f.readlines()
for line in content:
    m = re.search(r"\[(.*?)\]", line)
    print m.group(1)
    

Hope this helps:

Magic regex : \[(.*?)\]

Explanation:

\[ : [ is a meta char and needs to be escaped if you want to match it literally.

(.*?) : match everything in a non-greedy way and capture it.

\] : ] is a meta char and needs to be escaped if you want to match it literally.

撞了怀 2024-12-29 12:24:00

此代码片段也应该有效,但它将返回“[]”内包含的任何文本

re.findall(r"\[([a-zA-Z0-9 ._]*)\]", your_text)

This snippet should work too, but it will return any text enclosed within "[]"

re.findall(r"\[([a-zA-Z0-9 ._]*)\]", your_text)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文