我正在尝试创建一个数据帧来存储reddit数据:
for (i in 1:length(a)){
if(is.element(df$a[i],c) == TRUE){
df$b[i] <- "Yes"
}
else if (is.element(df$a[i],d) == TRUE){
df$b[i] <- "No"
}
else{
df$b[i] <- NA
}
}
答案 0 :(得分:2)
在行继续反斜杠和换行符之间有任何内容是非法的。 1 (有关详细信息,请参阅Explicit line joining。)
通常,这个问题非常明显:
>>> 'abc' \stuff
'abc' \stuff
^
SyntaxError: unexpected character after line continuation character
...但是要看起来要难得多,即使是非法的,如果你拥有的只是空白:
>>> 'abc' \
'abc' \
^
SyntaxError: unexpected character after line continuation character
如果您在同一来源中混合使用Windows \r\n
和Unix \n
换行符,情况会更糟。然后,您可以使用反斜杠后跟一个\r\n
,看起来非常好 - 但\r
被视为非法空格,而不是新行的一部分,因为它将您的脚本视为{{1 }} - 封端的 2
一个体面的编辑会使这些问题难以创建,易于发现,或两者兼而有之。几乎除了Notepad和TextEdit之外的任何编辑器都被认为是“体面的”用于这些目的,包括为每个平台提供大量免费的。
解决方案是删除\n
之后的任何空格。
或者更好的是,避免在不需要时使用反斜杠延续 - 因为你不在这里,因为\
,{}
或[]
中的任何表达式自动继续,无需反斜杠。 (有关详细信息,请参阅Implicit line joining,但它几乎总是按照您的预期运作。)
<子> 1。从技术上讲,我认为除了换行之外的其他东西后面的反斜杠根本不是一个续行。所以实际的错误只是反斜杠本身就是一个无效的令牌。但是如果是这样的话,这里的标记器很好,它提供了一个更容易理解的错误信息,所以我们不要抱怨......
<子> 2。我相信这个可能不再是真的......大概在2.6左右,或者3.0左右?见Physical lines。但是,更好地使用一致的结尾而不是希望Python正确猜出你想要做什么...
答案 1 :(得分:1)
为什么不使用:
topics_dict = { "title":[],
"score":[],
"id":[],
"url":[],
"comms_num": [],
"created": [],
"body":[]}
并删除\
它完全相同的事情。
这对于dictionary完全有效,并且不受字符串等新行的影响(只要缩进是正确的)。