我正在使用Python (和Pytumblr),并试图从一些返回的数据中提取特定的字符串,但是我正在搜索的字符串中包含":“。每当我运行我的脚本时,我都会得到错误:
File "myfile.py", line 22
if re.search('^ion': u'..', u'b', line) :
^
SyntaxError: invalid syntax这是我的代码:
import pytumblr
import re
returned = client.submission('blog') # get the submissions for a given blog
sch = open('returned')
for line in sch:
line = line.rstrip()
if re.search('^ion': u'..', u'b', line) :
print line这段代码中是否有另一个错误,或者是否有一种我不知道的逃避方法?我对Python非常陌生,但我并没有想到:需要逃跑。
发布于 2017-03-25 03:59:47
这是语法错误,因为冒号不是字符串的一部分。单引号'标记正在关闭字符串。你的第一个论点被解析为:
'^ion' - String 1: ^ion
: - Syntactical colon
u - The syntactical character u,
indicating you intend for the
following string literal to be
in unicode
'..' - String 2: ..如果希望^ion末尾的单引号成为字符串的一部分,则需要用反斜杠'^ion\':转义,或者在字符串本身周围使用双引号。由于Python接受字符串文字标记的单引号和双引号,所以'hello'和"hello"的含义相同。使'"hello world"'和"'hello world'"都成为合法的字符串。
如果正则表达式是这里的痛点,那么有大量的文献和工具可以提供帮助。我推荐regex101
发布于 2017-03-25 03:59:15
试着使用双引号:
re.search("^ion': u'..', u'b", line):或者逃逸'
re.search('^ion\': u\'..\', u\'b', line):https://stackoverflow.com/questions/43012320
复制相似问题