Python错误:行继续符后面的意外字符

时间:2018-06-01 20:06:56

标签: python

我正在尝试创建一个数据帧来存储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
    }
  }

2 个答案:

答案 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完全有效,并且不受字符串等新行的影响(只要缩进是正确的)。