Как применить жирный стиль к определенному слову в файле Excel, используя Python? - PullRequest
3 голосов
/ 20 сентября 2008

Я использую pyexcelerator модуль Python для генерации файлов Excel. Я хочу применить жирный стиль к части текста ячейки, но не ко всей ячейке. Как это сделать?

Ответы [ 2 ]

2 голосов
/ 21 сентября 2008

Найденный пример здесь: Создать файл в формате Excel прямо в Python

Обратите внимание, что вы создаете объект шрифта, а затем передаете его объекту стиля и затем предоставляете этот объект стиля при записи на лист:

import pyExcelerator as xl

def save_in_excel(headers,values):
    #Open new workbook
    mydoc=xl.Workbook()
    #Add a worksheet
    mysheet=mydoc.add_sheet("test")
    #write headers
    header_font=xl.Font() #make a font object
    header_font.bold=True
    header_font.underline=True
    #font needs to be style actually
    header_style = xl.XFStyle(); header_style.font = header_font
    for col,value in enumerate(headers):
        mysheet.write(0,col,value,header_style)
    #write values and highlight those that match my criteria
    highlighted_row_font=xl.Font() #no real highlighting available?
    highlighted_row_font.bold=True
    highlighted_row_font.colour_index=2 #2 is red,
    highlighted_row_style = xl.XFStyle(); highlighted_row_style.font = highlighted_row_font
    for row_num,row_values in enumerate(values):
        row_num+=1 #start at row 1
        if row_values[1]=='Manatee':
            for col,value in enumerate(row_values):
                #make Manatee's (sp) red
                mysheet.write(row_num,col,value,highlighted_row_style)
        else:
            for col,value in enumerate(row_values):
                #normal row
                mysheet.write(row_num,col,value)
    #save file
    mydoc.save(r'C:testpyexel.xlt')

headers=['Date','Name','Localatity']
data=[
['June 11, 2006','Greg','San Jose'],
['June 11, 2006','Greg','San Jose'],
['June 11, 2006','Greg','San Jose'],
['June 11, 2006','Greg','San Jose'],
['June 11, 2006','Manatee','San Jose'],
['June 11, 2006','Greg','San Jose'],
['June 11, 2006','Manatee','San Jose'],
]

save_in_excel(headers,data)
1 голос
/ 20 сентября 2008

Это пример из документации Excel:

With Worksheets("Sheet1").Range("B1")
    .Value = "New Title"
    .Characters(5, 5).Font.Bold = True
End With

Таким образом, свойство Characters ячейки, которой вы хотите манипулировать, является ответом на ваш вопрос. Он используется в качестве символов ( начало , длина ).

PS: я никогда не использовал данный модуль, но я использовал автоматизацию Excel COM в скриптах Python. Свойство «Персонажи» доступно через win32com.

...