xlrd исходное значение ячейки

Я читаю файл xls, используя xlrd. Проблема в том, что когда xlrd читает такое значение, как "12/09/2012", я получаю результат, подобный этому "xldate:41252.0". Когда я использую xlrd.xldate_as_tuple, я получаю следующий результат:

(2016, 12, 10, 0, 0, 0)

Мой код:

curr_row = -1
while curr_row < num_rows:
    curr_row += 1
    row = worksheet.row(curr_row)     
        for x in xrange(num_cols):
            field_type = worksheet.cell_type(curr_row, x)
            if field_type == 3: # this is date
                field_value = worksheet.cell_value(curr_row, x)
                print worksheet.cell(curr_row, x).value
                print xlrd.xldate_as_tuple(field_value, 1)

Результат:

41252.0
(2016, 12, 10, 0, 0, 0)

Оба результата неверны для меня. Как я могу получить исходное значение ячейки «09.12.2012», используя xlrd?


person artyomboyko    schedule 26.04.2013    source источник


Ответы (1)


Согласно строке документации, вы должны передать режим даты рабочей книги на xldate_as_tuple в качестве второго параметра:

from datetime import datetime
import xlrd


book = xlrd.open_workbook("test.xls")
sheet = book.sheet_by_index(0)
a1 = sheet.cell_value(rowx=0, colx=0)

print a1  # prints 41252.0
print xlrd.xldate_as_tuple(a1, 1)  # prints (2016, 12, 10, 0, 0, 0)

a1_tuple = xlrd.xldate_as_tuple(a1, book.datemode)  
print a1_tuple  # prints (2012, 12, 9, 0, 0, 0)

a1_datetime = datetime(*a1_tuple)
print a1_datetime.strftime("%m/%d/%Y")  # prints 12/09/2012
person alecxe    schedule 26.04.2013
comment
помогает ! но есть ли способ получить исходную строку 09.12.2012? - person artyomboyko; 26.04.2013