使用Python将列表写入Excel文件

时间:2014-08-29 10:31:11

标签: python excel date-format

我有一个列表要导出到保存适当格式的Excel文件,我使用了一个名为xlsxwriter的库,

这是一个例子: xlsxwriter

这是我的清单:

{'FirstName': u'Forence','LastName': u'Bidorst', 'Salary': -6775000.0, 'BirthDate': datetime.datetime(2013, 6, 20, 0, 0)}
{'FirstName': u'Oliver','LastName': u'Bidorst', 'Salary': -6775000.0, 'BirthDate': datetime.datetime(2013, 6, 20, 0, 0)}
{'FirstName': u'Mathew','LastName': u'Stark', 'Salary': -6775000.0, 'BirthDate': datetime.datetime(2013, 6, 20, 0, 0)}
{'FirstName': u'Sphed','LastName': u'liomst', 'Salary': -6775000.0, 'BirthDate': datetime.datetime(2013, 6, 20, 0, 0)}

我修改了代码以浏览列表并将其插入文件

def export_result_XL():
 list=get_list()
 ...

 # Write some data headers.
 worksheet.write('A1', 'First Name', bold)
 worksheet.write('B1', 'Last Name', bold)
 worksheet.write('C1', 'Salary', bold)
 worksheet.write('D1', 'Birth Date', bold)

 # Some data we want to write to the worksheet.

 for entry in list:
     x = str(entry['FirstName'])
     y = str(entry['LastName'])
     z = str(entry['Salary'])
     e = str(entry['BirthDate'])
     v = BirthDate[:10]  # because the date format is like yyyy-mm-dd 00:00:00

     expenses = (
             [x,y ,z ,v]
                 )

 # Start from the first cell below the headers.
 row = 1
 col = 0
for item ,str1,str2,str3,date_str in (expenses):
 # Convert the date string into a datetime object.
 date = datetime.strptime(date_str, "%Y-%m-%d")

 worksheet.write_string  (row, col,     str1              )
 worksheet.write_string  (row, col + 1,     str2              )
 worksheet.write_string(row, col + 2,     str3              )
 worksheet.write_datetime(row, col + 3, date, date_format )


     row += 1

 # Write a total using a formula.
 #worksheet.write(row, 0, 'Total', bold)
 #worksheet.write(row, 2, '=SUM(C2:C5)', money_format)

 workbook.close()

 return ''

我有两个问题:

1 -

 for item, date_str in (frais) 
        ValueError: too many values ​​to unpack 

2- 如果我避免转换为日期格式,文件将被处理,但列和行被翻转

有什么想法怎么做,我希望我在描述中很清楚

1 个答案:

答案 0 :(得分:1)

最后我找到了一个解决方案:

 row = 1
 col = 0
 for entry in list:
    print entry

    strdate=str(entry['BirthDate'])
    formatdate=strdate[:10]
    date = datetime.strptime(str(formatdate), "%Y-%m-%d")

    worksheet.write_string  (row, col,     entry['FirstName']              )
    worksheet.write_string  (row, col+1,     entry['LastName']              )
    worksheet.write_number  (row, col+6,     entry['Salary'],number_format  )
    worksheet.write_datetime(row, col+10,    date, date_format )
    row += 1

 workbook.close()