从csv文件中读取时索引超出范围

时间:2017-10-24 17:39:15

标签: python

此代码从文本文件中读取数据,然后按照每行中包含的数字(从最低到最高)对程序创建的列表进行排序,然后程序应该与列表中的一个输入的名称匹配,然后继续计算那些人的位置。

以下是代码:

def Rank():
  #Declare List
  RankList=[]
  #Opening and reading the file
  with open('GolfInfo.txt','rU') as csvfile:
        reader=csv.reader(csvfile)
        for row in reader:
              #Data added to list
              RankList.append(row)
  #List is sorted by amount of strokes taken (Total) from lowest to highest
  RankList.sort()
  index=0
  Position=0
  RankMessageFull=("")
  for row in RankList:
        #Checks to see if Name is present in the list
        if row[1] == Name.get():
            Position=index+1
            #These if-elif-else statements determine a suitable suffix for the rank
            if Position==1:
                  RankMessageFull=(Position,"st")
                  RankMessage.set(RankMessageFull)
            elif Position==2:
                  RankMessageFull=(Position,"nd")
                  RankMessage.set(RankMessageFull)
            elif Position==3:
                  RankMessageFull=(Position,"rd")
                  RankMessage.set(RankMessageFull)
            else:
                  RankMessageFull=(Position,"th")
                  RankMessage.set(RankMessageFull)

        else:
              index=index+1

文本文件显示:

63,April,"('-', 7)"
69,Betsy,"('-', 1)"
80,Laura,"('+', 10)"
93,Coco,"('+', 23)"

错误发生在以下行中:

if row[1] == Name.get():

但我不知道为什么。 完整的错误消息可以在这里看到:

if row[1] == Name.get():
  IndexError: list index out of range

RankMessage是Tkinter StringvarName也是Tkinter StringVar

1 个答案:

答案 0 :(得分:0)

csv文件中的行似乎只有一个或更少的项目。您可以通过下面显示的简单更改避免将它们添加到ggplot(df, aes(x=x, y=y))+facet_wrap(~Id, labeller = labeller(setNames(df$Id, df$Label)))+geom_point()。另请注意,您应该使用Python 3中的RankList选项open() csv文件。

newline=''