1

テキストファイルから記号「$」で始まるすべての単語を抽出するにはどうすればよいですか?

ファイル a (ASCII) -->

        @ExtendedAttr = nvp_add(@ExtendedAttr, "severity", $severity,  
 "description", $description, "eventID", $eventID,
             "eventURL", $eventURL, "alertLevel", $alertLevel, 
      "eventStart", $eventStart,
             "eventSourceCount", $eventSourceCount, "eventSourceTable", 
$eventSourceTable, "eventDestCount", $eventDestCount)

出力を次のようにしたい(すべて改行):

$severity
$description
$eventID
$eventURL
$alertLevel
$eventStart
$eventSourceCount
$eventSourceTable
$eventDestCount
4

2 に答える 2

2

使用regex:

>>> import re
>>> with open('filename') as f:
...     ans = []
...     for line in f:
...         matches = re.findall(r'(?<!\w)(\$\w+)', line)
...         ans.extend(matches)
...         
>>> print ans
['$severity', '$description', '$eventID', '$eventURL', '$alertLevel', '$eventStart', '$eventSourceCount', '$eventSourceTable', '$eventDestCount']

str.join期待される出力を取得するために使用します。

>>> print "\n".join(ans)
$severity
$description
$eventID
$eventURL
$alertLevel
$eventStart
$eventSourceCount
$eventSourceTable
$eventDestCount
于 2013-08-16T07:28:18.557 に答える
0

でのエスケープ$(通常は行末)に注意して、正規表現を使用してください\。ファイル全体を一度に読み取りますf.read()(読みやすくするために別の行に抽出することもできます)

import re

with open("filename", "r") as f:
...     matches = re.findall("(\$\w+)", f.read())
print matches
于 2013-08-16T08:13:37.033 に答える