4

所以我查看了类似的问题,但我仍然遇到同样的问题,无法弄清楚。对于这个编程任务,我正在为 Clite 词典的一小部分创建一个简化版本的词法分析。我正在从输入文件中提取标记,输出我的分析结果。我正在使用字典为找到的标识符创建一个符号表。当我在不同的行上找到相同的标识符时,我需要将找到它的行附加到符号表中。例如,我在第 2 行和第 7 行找到标识符“number18”。所以符号表需要从 {number18: 2} 到 {number18: 2,7}

当我尝试将新行号附加到当前字典条目时,问题就出现了。当我在问题标题中发布时,我收到了错误。到目前为止,这是我的代码

y = 0
s2 = ()
stable = dict()

for line in open("Sample.txt","r"):
    x1 = ''
    for char in line:
    if char.isalpha():
        x1 = x1 + char
    elif char.isdigit():
        x1 = x1 + char
    elif char == '.':
        x1 = x1 + char
    elif x1 != '':
        break

    #print (x1)    
    if (x1 == "for" or x1 == "bool" or x1 == "char" or x1 == "else" or x1 == "false" or x1 == "float" or x1 == "if" or x1 == "int" or x1 == "main" or x1 == "true" or x1 == "while"):
        s2=(y,"Keyword",x1)
    elif x1.isidentifier():
        s2=(y,"Identifier",x1)
    if x1 in stable.keys():
        stable[x1].append(y)
    else:
        stable[x1]=y


    elif x1.isdigit():
        s2=(y,"Int",x1)
    else:
        s2=(y,"Float",x1)
    print (s2)
    y=y+1

print (stable)
4

2 回答 2

17

您首先将您的dict值设置为int

    stable[x1]=y

但后来你试着把它当作一个list

    stable[x1].append(y)

list包含你的第一个开始int

    stable[x1]=[y]

并且.append()意志奏效。

或者,您可以使用defaultdict

stable = defaultdict(list)

然后随意附加而无需测试密钥是否已经存在:

    stable[x1].append(y)  # No need to do `if x1 in stable`.
于 2012-11-13T16:55:58.337 回答
6
elif x1.isidentifier():
    s2=(y,"Identifier",x1)
    if x1 in stable.keys():
        stable[x1].append(y)
    else:
        stable[x1]=y

在上面的 else 部分中,您是integer第一次添加。因此,当您append下次使用时,您会收到该错误。

当您第一次将值添加到 dict 时,而是将整数包装y在列表中[y]

    else:
        stable[x1]=[y]

好吧,您已经从@Martijn 的回答中知道,在这里使用 adefaultdict会是更好的选择,因为这样您就不需要检查containmentof key

但是,仍然与您检查 dict 中的键的方式有关:-

if x1 in stable.keys():

您不需要使用stable.keys(),只需使用stablekeys它只会签入。

if x1 in stable:
于 2012-11-13T16:56:03.533 回答