要求:
讀取以下表格中所有字體為大紅色或者單元格顏色為黃色的信息
利用到的模塊是:openpyxl
import openpyxl
filename="colortest.xlsx"#讀取excel
workbook=openpyxl.load_workbook(filename)
worksheet=workbook.get_sheet_by_name("試題2")#讀取Sheet
rows,cols=worksheet.max_row,worksheet.max_column
yellow=[]
red=[]
for i in range(1,rows):
for j in range(1,cols):
ce=worksheet.cell(row=i,column=j)
fill = ce.fill
font = ce.font
if fill.start_color.rgb=="FFFFFF00" and ce.value!=None:
yellow.append(ce.value)
if font.color.rgb=="FFFF0000":
red.append(ce.value)
print(yellow,red)
結(jié)果:
補充:python操作Excel和Docx并控制文字的顏色及其他樣式(通俗易懂)
1、Excel
from xlsxwriter.workbook import Workbook
workbook = Workbook(r'test.xlsx') # 創(chuàng)建xlsx
worksheet = workbook.add_worksheet('A') # 添加sheet
red = workbook.add_format({'color':'red'}) # 顏色對象
worksheet.write(0, 0, 'sentences') # 0,0表示row,column,sentences表示要寫入的字符串
test_list = ["我愛", "中國", "天安門"]
test_list.insert(1, red) # 將顏色對象放入需要設(shè)置顏色的詞語前面
print(test_list)
worksheet.write_rich_string(1, 0, *test_list) # 寫入工作簿
workbook.close() # 記得關(guān)閉
結(jié)果如下:
2、Docx
from docx import Document # pip install python-docx
from docx.shared import RGBColor, Pt
from docx.oxml.ns import qn
content = ["我愛", "中國"," 北京"]
print(content)
# 創(chuàng)建文檔對象
document = Document()
# 創(chuàng)建段落對象,注意,里面的內(nèi)容會顯示在段落開頭
para = document.add_paragraph('段落0\n')
# 往para段落對象中添加正文內(nèi)容
para.add_run(content[0])
# 往para對象添加內(nèi)容的同時返回內(nèi)容對象run,之后可以通過這個run對象給這個部分的文字設(shè)置樣式,比如顏色,大小,字體等
run = para.add_run(content[1])
# 給run對象設(shè)置字體顏色屬性, RGBColor(250,0,0)表示紅色
run.font.color.rgb = RGBColor(250,0,0)
# 給run對象設(shè)置字體大小屬性
run.font.size = Pt(20)
# 給run對象設(shè)置字體類型屬性
run.font.name = u'宋體'
run._element.rPr.rFonts.set(qn('w:eastAsia'), u'宋體')
# para對象中添加其他內(nèi)容
para.add_run(content[2])
# 保存
document.save('test.docx')
結(jié)果如下:
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- 如何用python合并多個excel文件
- Python 如何寫入Excel格式和顏色
- python讀寫修改Excel之xlrd&xlwt&xlutils
- Python處理excel根據(jù)全稱自動填寫簡稱
- python 刪除空值且合并excel的操作
- Python 對Excel求和、合并居中的操作