python實(shí)現(xiàn)對(duì)excel中需要的數(shù)據(jù)的單元格填充顏色
前言:
一般處理數(shù)據(jù)使用的是pandas和numpy庫(kù),但是填充單元格顏色需要在excel中,使用的是openpyxl庫(kù),所以不能直接達(dá)到我們的需求,需要進(jìn)行兩個(gè)庫(kù)的鏈接使用,先說(shuō)下openpyxl填充色,pandas是直接讀取數(shù)據(jù),但是openpyxl則不是,必須要sheet處于active狀態(tài),而且必須進(jìn)行sheet選擇才可以讀取數(shù)據(jù)
import openpyxl from openpyxl import load_workbook # 比如打開(kāi)test.xlsx wb = load_work(filename='test.xlsx') # 使用第一個(gè)sheet作為工作簿 work = wb[wb.sheetnames[0]]
openpyxl填充色說(shuō)明
調(diào)用openpyxl中PatternFill
純色填充使用solid
import openpyxl from openpyxl.styles import PatternFill #根據(jù)上面的work進(jìn)行單元格選擇 # 設(shè)置樣式(填充色) # 顏色必須使用hex 十六進(jìn)制并且沒(méi)有'#'符號(hào) 列舉為黃色 fill = PatternFill('solid',fgColor='FFFF00') # 填充D4為為黃色 d4 = work['D4'] d4.fill = fill
面臨一個(gè)問(wèn)題,我們需要?jiǎng)?chuàng)建Excel的列,比如’A’,‘B’,'C’等等
使用python產(chǎn)生26個(gè)英文字母.并進(jìn)行組合
import math import string def cycle_letter(arr,level): import string list1 = string.ascii_uppercase tempArr = [] letterArr = [i for i in list1] arrNum = len(arr) if(level==0 or arrNum==0): return letterArr for index in range(arrNum): for letter in letterArr: tempArr.append(arr[index]+letter) return tempArr def reduce_excel_col_name(num): tempVal = 1 level = 1 while(tempVal): tempVal = num/(math.pow(26, level)) if(tempVal>1): level += 1 else: break excelArr = [] tempArr = [] for index in range(level): tempArr = cycle_letter(tempArr,index) for numIndex in range(len(tempArr)): if(len(excelArr)<num): excelArr.append(tempArr[numIndex]) else: return excelArr return excelArr
可以填充數(shù)字,產(chǎn)生所需要的excel列
例:產(chǎn)生31個(gè)
案例:
這個(gè)是我們的數(shù)據(jù):
現(xiàn)在需要把所有大于50(不包含50)的數(shù)字,進(jìn)行黃色標(biāo)注
# 導(dǎo)入所需的庫(kù) import math import string import openpyxl import pandas as pd from openpyxl import load_workbook # 如上圖,一共10列,從0到9 # 產(chǎn)生為10的excel對(duì)應(yīng)的列 def cycle_letter(arr,level): list1 = string.ascii_uppercase tempArr = [] letterArr = [i for i in list1] arrNum = len(arr) if(level==0 or arrNum==0): return letterArr for index in range(arrNum): for letter in letterArr: tempArr.append(arr[index]+letter) return tempArr def reduce_excel_col_name(num): tempVal = 1 level = 1 while(tempVal): tempVal = num/(math.pow(26, level)) if(tempVal>1): level += 1 else: break excelArr = [] tempArr = [] for index in range(level): tempArr = cycle_letter(tempArr,index) for numIndex in range(len(tempArr)): if(len(excelArr)<num): excelArr.append(tempArr[numIndex]) else: return excelArr return excelArr # 保存到charter_list charter_list = reduce_excel_col_name(10) # 循環(huán)data選出所有>50的數(shù)字 # 并取出index和col_index并保存到excel中 a = [] b = [] for i in range(len(data.values)): for y in data.values[i]: if y > 50: # 獲取行數(shù) a.append(i) # 獲取列數(shù) a.append(data.values[i].tolist().index(y)) b.append(a) a = [] # 列表中第一個(gè)代表的是行,第二個(gè)數(shù)字代表的是列 # 將第二個(gè)數(shù)使用charter_list產(chǎn)生的代替 # 因?yàn)榱斜淼牡诙€(gè)數(shù)對(duì)應(yīng)的也是charter_list的index for i in b: i[1] = charter_list[i[1]] # 這里需要注意的是excel都是從1開(kāi)始,所以我們的第一個(gè)數(shù) # 行數(shù)需要+1,但是因?yàn)橛辛忻?,1,2,3到9的存在,所以需要添加一個(gè)2 for i in b: i[0] = i[0]+2 # 將列表變?yōu)?A2','C2',符合excle的習(xí)慣 list_color_all = [x[1]+str(x[0]) for x in b] # 使用load_workbook加載excel數(shù)據(jù),進(jìn)行顏色填充 wb = load_workbook(filename='excel_col.xlsx') work = wb[wb.sheetnames[0]] fill = PatternFill("solid", fgColor='FFFF00') for i in list_color_all: work[i].fill = fill wb.close() wb.save('excel_col.xlsx')
運(yùn)行截圖:
到此這篇關(guān)于python實(shí)現(xiàn)對(duì)excel中需要的數(shù)據(jù)的單元格填充顏色的文章就介紹到這了,更多相關(guān)python對(duì)excel單元格填充顏色內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 淺談python多進(jìn)程共享變量Value的使用tips
- Python?pandas?DataFrame基礎(chǔ)運(yùn)算及空值填充詳解
- Python?Pandas多種添加行列數(shù)據(jù)方法總結(jié)
- Python如何利用pandas讀取csv數(shù)據(jù)并繪圖
- Python?pandas替換指定數(shù)據(jù)的方法實(shí)例
- 利用python將?Matplotlib?可視化插入到?Excel表格中
- Python利用pdfplumber實(shí)現(xiàn)讀取PDF寫(xiě)入Excel
- 如何利用python將Xmind用例轉(zhuǎn)為Excel用例
- Python+pandas編寫(xiě)命令行腳本操作excel的tips詳情
相關(guān)文章
Python利用FFT進(jìn)行簡(jiǎn)單濾波的實(shí)現(xiàn)
今天小編就為大家分享一篇Python利用FFT進(jìn)行簡(jiǎn)單濾波的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-02-02火遍網(wǎng)絡(luò)的python中秋節(jié)賀卡現(xiàn)在學(xué)還趕得上
中秋將至,我用python編寫(xiě)了個(gè)火遍網(wǎng)絡(luò)的中秋節(jié)賀卡,現(xiàn)在學(xué)起來(lái)還不晚,文中給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09