/ / Identyfikacja kodu koloru arkusza Excela za pomocą pakietu XLRD - python, excel, xlrd

Identyfikacja kodu kolorów arkusza Excel za pomocą pakietu XLRD - python, excel, xlrd

Piszę skrypt Pythona do odczytu danych z arkusza excel przy użyciu xlrd. Kilka komórek arkusza roboczego jest podświetlonych innym kolorem i chcę zidentyfikować kod koloru komórki. Czy istnieje jakiś sposób, aby to zrobić ? Przykład byłby naprawdę doceniony.

Odpowiedzi:

37 dla odpowiedzi № 1

Oto jeden sposób na poradzenie sobie z tym:

import xlrd
book = xlrd.open_workbook("sample.xls", formatting_info=True)
sheets = book.sheet_names()
print "sheets are:", sheets
for index, sh in enumerate(sheets):
sheet = book.sheet_by_index(index)
print "Sheet:", sheet.name
rows, cols = sheet.nrows, sheet.ncols
print "Number of rows: %s   Number of cols: %s" % (rows, cols)
for row in range(rows):
for col in range(cols):
print "row, col is:", row+1, col+1,
thecell = sheet.cell(row, col)
# could get "dump", "value", "xf_index"
print thecell.value,
xfx = sheet.cell_xf_index(row, col)
xf = book.xf_list[xfx]
bgx = xf.background.pattern_colour_index
print bgx

Więcej informacji na temat Grupa Google Python-Excel.


1 dla odpowiedzi nr 2

Ta funkcja zwraca wartość rgb tła komórki w krotce.

def getBGColor(book, sheet, row, col):
xfx = sheet.cell_xf_index(row, col)
xf = book.xf_list[xfx]
bgx = xf.background.pattern_colour_index
pattern_colour = book.colour_map[bgx]

#Actually, despite the name, the background colour is not the background colour.
#background_colour_index = xf.background.background_colour_index
#background_colour = book.colour_map[background_colour_index]

return pattern_colour