首頁  >  文章  >  後端開發  >  python使用openpyxl函式庫修改excel表格資料方法

python使用openpyxl函式庫修改excel表格資料方法

不言
不言原創
2018-05-04 16:00:077343瀏覽

這篇文章主要介紹了關於使用python使用openpyxl庫修改excel表格資料方法,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

1、openpyxl函式庫可以讀寫xlsx格式的文件,對於xls舊格式的文件只能用xlrd讀,xlwt寫來完成了。

簡單封裝類別:

#
from openpyxl import load_workbook
from openpyxl import Workbook
from openpyxl.chart import BarChart, Series, Reference, BarChart3D
from openpyxl.styles import Color, Font, Alignment
from openpyxl.styles.colors import BLUE, RED, GREEN, YELLOW
class Write_excel(object):
  def __init__(self,filename):
    self.filename = filename
    self.wb = load_workbook(self.filename)
    self.ws = self.wb.active
  def write(self, coord, value):
    # eg: coord:A1
    self.ws.cell(coord).value = value
    self.wb.save(self.filename)
  def merge(self, rangstring):
    # eg: rangstring:A1:E1
    self.ws.merge_cells(rangstring)
    self.wb.save(self.filename)
  def cellstyle(self, coord, font, align):
    cell = self.ws.cell(coord)
    cell.font = font
    cell.alignment = align
  def makechart(self, title, pos, width, height, col1, row1, col2, row2, col3, row3, row4):
    ''':param title:图表名
         pos:图表位置
         width:图表宽度
         height:图表高度
    '''
    data = Reference(self.ws, min_col=col1, min_row=row1, max_col=col2, max_row=row2)
    cat = Reference(self.ws, min_col=col3, min_row=row3, max_row=row4)
    chart = BarChart3D()
    chart.title = title
    chart.width = width
    chart.height = height
    chart.add_data(data=data, titles_from_data=True)
    chart.set_categories(cat)
    self.ws.add_chart(chart, pos)
    self.wb.save(self.filename)

簡單使用:

1、新excel檔案處理

#
wb = Workbook()#创建工作簿 
ws = wb.active#激活工作表 
ws1 = wb.create_sheet("Mysheet")#创建mysheet表 
ws.title = "New Title"#表明改为New Title 
ws.sheet_properties.tabColor = "1072BA"#颜色 
ws['A4'] = 4#赋值 
d = ws.cell(row=4, column=2, value=10)#赋值 
cell_range = ws['A1':'C2']#选择单元格区域 
wb.save('test.xlsx')#保存

2 、已有excel檔案的處理

a、修改excel資料

wr = Write_excel('d:\demo.xlsx') 
wr.write('A2','hello')

b、合併儲存格

wr.merge('A1:B3')

#c、儲存格加入樣式,如字體,顏色等屬性

單元格B2設定宋體,14號,紅色,自動換行,水平居中,垂直居中

font = Font(name=u'宋体', size=14, color=RED, bold=True)
align = Alignment(horizontal='center', vertical='center')
wr.cellstyle('B2', font, align)

d、創建3d柱狀圖片

rows = [ 
  (None, 2013, 2014), 
  ("Apples", 5, 4), 
  ("Oranges", 6, 2), 
  ("Pears", 8, 3) 
] 
 
for row in rows: 
  ws.append(row) 
 
wr.makechart(u"3D Bar Chart", 'E5', 12.5, 7, 2, 1, 3, 4, 1, 2, 4)

#可以建立3d柱狀和折線圖表,挺好用的。

相關推薦:

Python使用matplotlib實現的圖像讀取、切割裁剪功能範例

Python使用email模組對郵件進行編碼和解碼

#

以上是python使用openpyxl函式庫修改excel表格資料方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn