溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python調(diào)用xlsxwriter創(chuàng)建xlsx的方法

發(fā)布時(shí)間:2020-08-30 15:02:24 來源:腳本之家 閱讀:211 作者:hongliryan 欄目:開發(fā)技術(shù)

詳細(xì)的官方文檔可見:http://xlsxwriter.readthedocs.io/

通過pip安裝xlsxwriter

pip install xlsxwriter

下面進(jìn)行基本的操作演示:

1. 首先創(chuàng)建一個(gè)excel的文檔

workbook = xlsxwriter.Workbook(dir)

2. 在文檔中創(chuàng)建表

table_name = 'sheet1'
worksheet = workbook.add_worksheet(table_name) # 創(chuàng)建一個(gè)表名為‘sheet1'的表,并返回這個(gè)表對象

3. 創(chuàng)建表后,就可以在表格上面進(jìn)行寫入操作

worksheet.write_column('A1', 5) # 在A1單元格寫入數(shù)字5

有時(shí)候,我們想修改輸入內(nèi)容的格式,例如設(shè)置字體顏色加粗,斜體,日期格式等,這時(shí)候,就可以通過使用xlsxwriter提供的格式類。

具體可見:http://xlsxwriter.readthedocs.io/format.html

下面以寫入一個(gè)粗體的紅色的日期類為例

import datetime
# 需要先把字符串格式化成日期
date_time = datetime.datetime.strptime('2017-1-25', '%Y-%m-%d')
# 定義一個(gè)格式類,粗體的紅色的日期
date_format = workbook.add_format({'bold': True, 'font_color': 'red', 'num_format': 'yyyy-mm-dd'})
# 寫入該格式類
worksheet.write_column('A2', date_time, date_format)


4. xlsxwriter支持很多圖表格式的插入

具體可以參見:http://xlsxwriter.readthedocs.io/chart.html

這里摘抄一段圖標(biāo)類型的介紹:

excel定義的圖分兩級類別描述,第一級分別有九大類,如下所示

area: 面積圖
bar: 轉(zhuǎn)置直方圖
column: 柱狀圖
line: 直線圖
pie: 餅狀圖
doughnut: 環(huán)形圖
scatter: 散點(diǎn)圖
stock: 股票趨勢圖
radar: 雷達(dá)圖

第二級則是描述是否有連線,是否有平滑曲線等細(xì)節(jié)調(diào)整。

area
 stacked
 percent_stacked
bar
 stacked
 percent_stacked
column
 stacked
 percent_stacked
scatter
 straight_with_markers
 straight
 smooth_with_markers
 smooth
radar
 with_markers
 filled

下面舉例繪制一個(gè)散點(diǎn)圖。

chart1 = workbook.add_chart({'type': 'scatter', 'subtype': 'straight'})
chart1.set_title({'name': '圖1'})
chart1.add_series({
 'name': '系列1',
 # 集合范圍
 'categories': '=sheet1!$A$1:$A$89',
 # 數(shù)值范圍
 'values': '=sheet1!$B$1:$B$89'),
 # 是否連線
 'line': {'none': True},
 # 默認(rèn)圖格式
 'marker': {'type': 'automatic'},
})
# 設(shè)置y軸的范圍
chart1.set_y_axis({'max': 1.1, 'min': 0})
chart1.set_size({'x_scale': 2, 'y_scale': 2})
# 把圖例插入到表中的C2位置,并且設(shè)置橫軸偏移量為25,縱軸偏移量為10
worksheet.insert_chart('C2', chart1, {'x_offset': 25, 'y_offset': 10})

以上這篇

詳細(xì)的官方文檔可見:http://xlsxwriter.readthedocs.io/

通過pip安裝xlsxwriter

pip install xlsxwriter

下面進(jìn)行基本的操作演示:

1. 首先創(chuàng)建一個(gè)excel的文檔

workbook = xlsxwriter.Workbook(dir)

2. 在文檔中創(chuàng)建表

table_name = 'sheet1'
worksheet = workbook.add_worksheet(table_name) # 創(chuàng)建一個(gè)表名為‘sheet1'的表,并返回這個(gè)表對象

3. 創(chuàng)建表后,就可以在表格上面進(jìn)行寫入操作

worksheet.write_column('A1', 5) # 在A1單元格寫入數(shù)字5

有時(shí)候,我們想修改輸入內(nèi)容的格式,例如設(shè)置字體顏色加粗,斜體,日期格式等,這時(shí)候,就可以通過使用xlsxwriter提供的格式類。

具體可見:http://xlsxwriter.readthedocs.io/format.html

下面以寫入一個(gè)粗體的紅色的日期類為例

import datetime
# 需要先把字符串格式化成日期
date_time = datetime.datetime.strptime('2017-1-25', '%Y-%m-%d')
# 定義一個(gè)格式類,粗體的紅色的日期
date_format = workbook.add_format({'bold': True, 'font_color': 'red', 'num_format': 'yyyy-mm-dd'})
# 寫入該格式類
worksheet.write_column('A2', date_time, date_format)


4. xlsxwriter支持很多圖表格式的插入

具體可以參見:http://xlsxwriter.readthedocs.io/chart.html

這里摘抄一段圖標(biāo)類型的介紹:

excel定義的圖分兩級類別描述,第一級分別有九大類,如下所示

area: 面積圖
bar: 轉(zhuǎn)置直方圖
column: 柱狀圖
line: 直線圖
pie: 餅狀圖
doughnut: 環(huán)形圖
scatter: 散點(diǎn)圖
stock: 股票趨勢圖
radar: 雷達(dá)圖

第二級則是描述是否有連線,是否有平滑曲線等細(xì)節(jié)調(diào)整。

area
 stacked
 percent_stacked
bar
 stacked
 percent_stacked
column
 stacked
 percent_stacked
scatter
 straight_with_markers
 straight
 smooth_with_markers
 smooth
radar
 with_markers
 filled

下面舉例繪制一個(gè)散點(diǎn)圖。

chart1 = workbook.add_chart({'type': 'scatter', 'subtype': 'straight'})
chart1.set_title({'name': '圖1'})
chart1.add_series({
 'name': '系列1',
 # 集合范圍
 'categories': '=sheet1!$A$1:$A$89',
 # 數(shù)值范圍
 'values': '=sheet1!$B$1:$B$89'),
 # 是否連線
 'line': {'none': True},
 # 默認(rèn)圖格式
 'marker': {'type': 'automatic'},
})
# 設(shè)置y軸的范圍
chart1.set_y_axis({'max': 1.1, 'min': 0})
chart1.set_size({'x_scale': 2, 'y_scale': 2})
# 把圖例插入到表中的C2位置,并且設(shè)置橫軸偏移量為25,縱軸偏移量為10
worksheet.insert_chart('C2', chart1, {'x_offset': 25, 'y_offset': 10})

以上這篇python調(diào)用xlsxwriter創(chuàng)建xlsx的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI