csv模块将时间写为十进制

时间:2012-11-13 15:51:58

标签: python excel csv xlrd

我遇到了一个问题,我在.xls文件中有一些数据(例如下面的例子)。

  A            B           C         D         E        F
John Smith     8:00AM      9:00AM    10:00AM    5:00PM  8.00

当我使用Python CSV模块将其写入csv时,它将显示为

John,Smith,0.333333333,0.375,0.416666667,0.708333333,0.333333333

现在有趣的部分是如果我手动将xls文件保存为MSDOS csv我得到了所需的输出

John,Smith,8:00 AM,9:00 AM,10:00 AM,5:00 PM,8:00

这是我正在运行的功能。它有点乱,所以我提前道歉。

def csv_gen(filepath, saveto):
    for files in glob.glob("*.xls"):
        shutil.copy(filepath + "\\" + files, saveto)
        with xlrd.open_workbook(files) as wb:
            sh = wb.sheet_by_index(0)
            newfile = saveto + files[:-4] + '.csv'
            now = datetime.datetime.now()
            dates = now.strftime("%m-%d-%Y")
            filestart = [saveto + files]
            time = [dates]
            with open(newfile, 'wb') as f:
                c = csv.writer(f,delimiter=',')
                list =  range(sh.nrows)
                last = range(sh.nrows)[-1]
                list.remove(0)
                list.remove(3)
                list.remove(2)
                list.remove(1)
                list.remove(last)
                #Iterate through data and show values of the rows
                for r in list:
                    lines = sh.row_values(r)
                    del lines[:4]
                    stuff = lines + filestart + time
                    #Remove blanks so csv doesnt have uneeded data
                    if lines[0] is '':
                        del stuff[:]
                    #Write to csv file with new data
                    if any(field.strip() for field in stuff):
                        c.writerow(stuff)
            shutil.move(newfile, mergeloc)

我不明白为什么会这样出现。我已经尝试将方言标志添加到csv编写器为'excel',但输出仍然是相同的。

更新

如果我将文档另存为csv workBook.SaveAs(test.csv, 24)编码24用于MSDOS。我得到了所需的

输出
John,Smith,8:00 AM,9:00 AM,10:00 AM,5:00 PM,8:00

但是当csv模块抓取它并删除一些空行并在最后删除一些东西时它会将行写出来,这就是我再次得到小数的时候

John,Smith,0.333333333,0.375,0.416666667,0.708333333,0.333333333

csv模块的目的是修改行并删除空行。

更新

 for r in list: 
     cells = sh.row_values(r) 
     csv_row = cells[0] for col_value in cells[1:]:
         csv_row.append(datetime.time(*xlrd.xldate_as_tuple(col_value, 0)[3:])) 

添加了row_values以仅返回单元格的值而不是xldata:0.33333。然后添加一个*来使传递成为位置参数。

1 个答案:

答案 0 :(得分:2)

对我来说,csv模块中看起来不像是一个问题,看起来在阅读.xls文件时出现了问题。

根据Excel中的xlrd docs日期,工作表非常糟糕

  

Excel电子表格中的日期

     

实际上,没有这样的事情。你有什么浮点   数字和虔诚的希望。 Excel日期有几个问题:

我使用新的.xls文件对您提供的内容进行了快速测试。 Python在读取文件时没有问题,虽然我的机器上没有Excel,但我在LibreOffice中创建了文件并将其保存为.xls。即便如此,这些字段在python端也是unicode字符串。

您应该能够使用xlrd.xldate_as_tuple(xldate, datemode)link)将float转换为python日期元组。做

print xlrd.xldate_as_tuple(0.333333333,0)

打印出来

(0, 0, 0, 8, 0, 0)

<强>更新

所以你可能想要类似下面这样的东西,改变你行上的for循环

...
for r_idx in list:
    cells = sh.row(r)
    csv_row = [cells[0]] # the first row value should be ok as just a string
    for col_value in cells[1:]:
        # add the date time column values to the converted csv row
        csv_row.append( datetime.time(xlrd.xldate_as_tuple(col_value, 0)[3:]) )
    ...