IndexError:元组索引超出范围 - 从dict创建CSV

时间:2017-02-28 14:38:24

标签: python python-3.x csv index-error

我正在尝试从dict创建一个csv,但我收到以下错误。我最初使用的是键名而不是索引号,但是当我添加多个字典值时它会导致错误。

IndexError: tuple index out of range

代码:

#Create dict file to test
userInfoDict = {'orgID': '17', 'firstName': 'TestFirstName', 'lastName': 'TestLastName', 'emailAddress': 'test@test.com',
                    'phoneNumber': '1234567890', 'isoCountryCode': 'US'}, {'orgID': '27', 'firstName': 'TestFirstName2', 'lastName': 'TestLastName2', 'emailAddress': 'test2@test.com',
                    'phoneNumber': '5384537645', 'isoCountryCode': 'US'}


def create_csv(userInfoDict):
    import csv

    userInfo = open('userInfo.csv', 'w')

    for key in userInfoDict:
        if len(userInfoDict[0]) == 0:
            print('Not a valid user: No orgID')
            return None
        elif len(userInfoDict[1]) == 0:
            print('Not a valid user: No First Name')
            return None
        elif len(userInfoDict[3]) == 0 and len(userInfoDict[4]) == 0:
            print('Not a valid user: No Email or Phone')
            return None
        else:
            writer = csv.DictWriter(userInfo, fieldnames=userInfoDict.keys(), delimiter=',')
            #writer.writeheader()  # If you want to add header
            writer.writerow(userInfoDict)
        return

create_csv(userInfoDict)

2 个答案:

答案 0 :(得分:1)

您提供的userInfoDicttuple两个dicts,相当于: userInfoDict = ({'orgID': '17', 'firstName': 'TestFirstName', 'lastName': 'TestLastName', 'emailAddress': 'test@test.com','phoneNumber': '1234567890', 'isoCountryCode': 'US'}, {'orgID': '27', 'firstName': 'TestFirstName2', 'lastName': 'TestLastName2', 'emailAddress': 'test2@test.com', 'phoneNumber': '5384537645', 'isoCountryCode': 'US'} )

然而,您正在尝试计算len(userInfoDict[3])。它没有索引为3的元素,只有索引0和1。

答案 1 :(得分:0)

这是因为你的'userInfoDict'是长度为2的元组。

len(userInfoDict)
2

但是你似乎试图在你的代码中访问'userInfoDict [3]'和userInfoDict [4]。

见下文

userInfoDict[0]
{'emailAddress': 'test@test.com',
'firstName': 'TestFirstName',
'isoCountryCode': 'US',
'lastName': 'TestLastName',
'orgID': '17',
'phoneNumber': '1234567890'}

userInfoDict[1]
{'emailAddress': 'test2@test.com',
'firstName': 'TestFirstName2',
'isoCountryCode': 'US',
'lastName': 'TestLastName2',
'orgID': '27',
'phoneNumber': '5384537645'}

因此,超过1的任何索引都会使您退出索引错误

userInfoDict[2]
IndexError: tuple index out of range

请检查你的'userInfoDict'不是dict,它是一个元组。