0

这是我到目前为止所做的程序的代码。我正在尝试计算 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)

我不知道如何发布数据文件供您查看和尝试,但是任何以逗号分隔的数字文件都应该可以使用。

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

玻利弗

4

1 回答 1

3

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

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)
于 2012-12-03T00:14:29.920 回答