我正在尝试用已知字符串(例如“ NAN”)替换列表中的空字符串。我正在使用以下命令

a = ['','','asdf']
["nan" if x =='' else x for x in a]


该代码在单独使用时可以正常工作,但是当我尝试在主代码中使用它时,则无法正常工作。我的主要代码如下:

data = [ ('plant_data.xlsx', 0, []),('sorg.xlsx', 1, ['','','asdf'])]#,('sloc.xlsx', 1, ['307-040N'])];


for fl in data:
    filename = fl[0];
    filename = filename[:-5];

    f = open('IC1_Results\%s.txt' %filename,'w');

    if fl[1] == 0:
        f.write("All Part Numbers exist");
        f.close()

    elif fl[1] == 1:
        a = fl[2];
        print type(a)

        ["nan" if x == '' else x for x in a]

        print fl[2],a

最佳答案

它正在工作,但是您只是在运行它而无需将输出分配到任何位置。用以下方法更改行:

fl[2] = ["nan" if x == '' else x for x in a]


或许:

a = ["nan" if x == '' else x for x in a]


根据您要存储的位置...

关于python - 用NaN替换列表中的空字符串,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/51045771/

10-11 21:37