我不能分开工作,我做错了什么



这是我到目前为止完成的程序的代码。 我正在尝试计算NBA球员在课堂项目中的效率。 当我在包含所有统计信息的逗号分隔文件上运行程序时,它不是在每个逗号上拆分,而是创建统计信息文件整行的列表条目。 我得到一个超出范围的索引错误,或者它将每个字符视为索引点而不是单独的字段。 我是新手,但似乎应该为文件中的每一行创建一个列表,该列表由该列表的元素分隔,所以我得到了一个列表列表。 我希望我已经让自己明白了。

这是代码:

def get_data_list (file_name):
    data_file = open(file_name, "r")
    data_list = []
    for line_str in data_file:
        # strip end-of-line, split on commas, and append items to list
        line_str.strip()       
        line_str.split(',')
        print(line_str)
        data_list.append(line_str)
        print(data_list)                



file_name1 = input("File name: ")
result_list = get_data_list (file_name1)

print(result_list)

我不明白如何发布数据文件供您查看和尝试,但任何逗号分隔的数字文件都应该有效。

如果有办法将数据文件或电子邮件发布给您,以便您帮助我,我很乐意这样做。

博利弗

字符串是不可变的对象,这意味着您无法就地更改它们。这意味着,对字符串的任何操作都会返回一个新操作。现在看看你的代码:

line_str.strip()            # returns a string      
line_str.split(',')         # returns a list of strings
data_list.append(line_str)  # appends original 'line_str' (i.e. the entire line)

您可以通过以下方式解决此问题:

stripped = line_str.strip()
data = stripped.split(',')
data_list.append(data)

或者连接字符串操作:

data = line_str.strip().split(',')
data_list.append(data)

相关内容

最新更新