成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

使用python庫xlsxwriter庫來輸出各種xlsx文件的示例

瀏覽:35日期:2022-07-12 16:11:32

功能性的文章直接用幾個最簡單的實現表達:

xlsxwriter庫的核心就是其Workbook對象。

創建一個指定名字的xlsx文件:

import xlsxwriterfilename = ’/Users/piperck/Desktop/axiba.xlsx’test_book = xlsxwriter.Workbook(filename)worksheet = test_book.add_worksheet()test_book.close()

創建一個Workbook的實例對象。可以傳入一個文件名字,如果不想生成的文件在當前路徑下面,可以在文件名字前面帶上絕對路徑。

add_worksheet()就是增加一個sheet

然后關閉這個對象,完成xlsx文件的生成。

創建一個指定名字的sheet并且為其添加一些數據:

import xlsxwriterfilename = ’/Users/piperck/Desktop/axiba.xlsx’test_book = xlsxwriter.Workbook(filename)worksheet = test_book.add_worksheet(’what’)expenses = ( [’Rent’, 1000], [’Gas’, 100], [’Food’, 300], [’Gym’, 50],)# 定義起始的行列 會在這個基礎上 行列各加一 作為初始行列row = 0col = 0for item, cost in expenses: worksheet.write(row, col, item) worksheet.write(row, col+1, cost) row += 1worksheet.write(row, col, ’=sum(B0:B4)’)test_book.close()

我們可以使用得到的worksheet對象來添加其行列數據,如上所示。注意最后添加數據可以直接在第三個參數里面使用函數。

創建一個有指定樣式的Workbook:

這個方法其實。。應該有非常多的參數,大家根據實際需要可以具體去查詢更多的屬性。這個樣式要在Workbook的對象上加。

import xlsxwriterfilename = ’/Users/piperck/Desktop/axiba.xlsx’test_book = xlsxwriter.Workbook(filename)worksheet = test_book.add_worksheet(’what’)bold = test_book.add_format({’bold’: True})test_book.add_format()expenses = ( [’Rent’, 1000], [’Gas’, 100], [’Food’, 300], [’Gym’, 50],)# 定義起始的行列 會在這個基礎上 行列各加一 作為初始行列row = 0col = 0for item, cost in expenses: worksheet.write(row, col, item, bold) worksheet.write(row, col+1, cost) row += 1test_book.close()

關于更多的參數,完全可以參看源代碼里面的property字典下面初始化的那一堆東西,應該都是。

根絕著就能解決大部分問題了,如果有更多的需求就查閱下面的文檔即可。

通用做法可能會基于此再做一些東西來包裝 xlsxwriter 來讓他更好用,這個就看大家對自己業務需要抽象的能力了。

Reference:

https://xlsxwriter.readthedocs.io xlsxwriter doc

在當前文件夾生成

#coding=utf-8def get_excel(): ''' 生成excel :return: ''' import xlsxwriter workbook = xlsxwriter.Workbook('test.xlsx') worksheet = workbook.add_worksheet() # 樣式 formats = Struct() # 字典轉化為點語法 formats.base = {'font_name': u'宋體', 'font_size': 11, 'align': 'center', 'valign': 'vcenter', 'text_wrap': True} # formats.condition = dict_merge(formats.base, {'align': 'left'}) formats.bold = {'bold': True} # 加粗 formats.row = dict_merge(formats.base, {'border': 1}) formats.first_row = dict_merge(formats.row, {'bold': True}) # 首行 formats.more_row = dict_merge(formats.row, {}) # 普通行 formats.more_row_even = dict_merge(formats.row, {'bg_color': '#dddddd'}) # 普通行-奇數 # 篩選條件行 worksheet.merge_range(’A1:F1’, '') # 合并單元格 conditions_list = [] # 條件 province = ’省’ city = ’市’ county = ’地區’ name = ’姓名’ phone = ’電話’ date = ’2018-6’ if province or city or county: area_name = province + city + county conditions_list.append(workbook.add_format(formats.bold)) conditions_list.append(u’地區:’) conditions_list.append(u’%s ’ % area_name) if name: conditions_list.append(workbook.add_format(formats.bold)) conditions_list.append(u’姓名:’) conditions_list.append(u’%s ’ % name) if phone: conditions_list.append(workbook.add_format(formats.bold)) conditions_list.append(u’手機:’) conditions_list.append(u’%s ’ % phone) if date: year, month = date[0:4], date[5:7] conditions_list.append(workbook.add_format(formats.bold)) conditions_list.append(u’創建時間:’) conditions_list.append(u’%s/%s ’ % (year, month)) if conditions_list: # 如果有條件 worksheet.write_rich_string(’A1’, *conditions_list) # 首行 # 表格首行 cols = ['姓名', '電話', '地區'] for col_index, col in enumerate(cols): worksheet.write(1, col_index, col, workbook.add_format(formats.first_row)) # 第二行,col_index列, col_index從0開始,也就是第一列開始 data_list = [{'name': 'Spencer', 'tel': '13888888888', 'reg': '中國'},{'name': 'Jeff', 'tel': '139999999999', 'reg': '臺灣省'}] # 表格其余行 for row_index, u in enumerate(data_list, start=2): # 因為前兩行都被占用了,所以從第三行第一列開始 # 斑馬條 if row_index % 2 != 0: row_format = formats.more_row # excel格式普通行 else: row_format = dict_merge(formats.more_row_even) # excel格式奇數行# 日期格式 date_format = dict_merge(row_format, {'num_format': 'yyyy/mm/dd hh:mm'}) # 靠左 left_format = dict_merge(row_format, {'align': 'left'}) # 第一個參數:行,第二個參數:列,第三個參數:數據,第四個參數:屬性 worksheet.write(row_index, 0, u[’name’], workbook.add_format(row_format)) worksheet.write(row_index, 1, u[’tel’], workbook.add_format(row_format)) worksheet.write(row_index, 2, u[’reg’], workbook.add_format(row_format)) # 列寬 # 第一個參數是第幾列開始,第二個人參數是從第幾列結束 # 比如下方第一個就是設置第一列為20,第二個就是設置第二列為10,第三個就是設置3到6列為20 worksheet.set_column(0, 0, 20) worksheet.set_column(1, 1, 10) worksheet.set_column(2, 5, 20) workbook.close()def dict_merge(*args): ''' 功能說明:合并字典 ''' all = {} for arg in args: if not isinstance(arg, dict): continue all.update(arg) return allclass Struct(dict): ''' - 為字典加上點語法. 例如: >>> o = Struct({’a’:1}) >>> o.a >>> 1 >>> o.b >>> None ''' def __init__(self, dictobj={}): self.update(dictobj) def __getattr__(self, name): # 如果有則返回值,沒有則返回None if name.startswith(’__’): raise AttributeError return self.get(name) def __setattr__(self, name, val): self[name] = val def __hash__(self): return id(self)if __name__ == ’__main__’: get_excel()

到此這篇關于使用python庫xlsxwriter庫來輸出各種xlsx文件的示例的文章就介紹到這了,更多相關python xlsxwriter輸出xlsx內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产成人亚洲综合a∨婷婷图片| 91超碰这里只有精品国产| 日本韩国欧美三级| 亚洲国产一区二区在线播放| 精品动漫av| 欧美成人r级一区二区三区| 久久99国产精品成人| 一本久久综合亚洲鲁鲁五月天| 精品黑人一区二区三区久久 | 欧美1区3d| 欧美大片在线观看| 国产99精品国产| 欧美福利电影网| 国产在线精品不卡| 这里只有精品99re| 欧美视频在线观看一区二区| 青青草国产精品亚洲专区无| 欧美性大战久久久久久久| 麻豆高清免费国产一区| 欧美性猛交xxxxxx富婆| 寂寞少妇一区二区三区| 欧美视频一区二区在线观看| 精品亚洲成a人在线观看| 欧美亚洲高清一区| 美女视频黄免费的久久| 欧美日韩亚洲丝袜制服| 韩国女主播一区二区三区| 亚洲在线观看免费视频| 久久亚洲二区| 精品一区二区av| 日韩三级在线观看| av毛片久久久久**hd| 国产欧美日本一区视频| 影音先锋久久精品| 玉米视频成人免费看| 免费中文字幕日韩欧美| 日韩av在线免费观看不卡| 色屁屁一区二区| 精品一区二区三区蜜桃| 91精品国产91综合久久蜜臀| 成人av综合一区| 中文字幕av不卡| 国产美女在线精品免费观看| 秋霞国产午夜精品免费视频| 在线播放欧美女士性生活| www.综合网.com| 中文字幕一区三区| 性色一区二区三区| 狠狠色狠狠色综合系列| 精品国产成人系列| 尹人成人综合网| 亚洲a一区二区| 欧美肥妇bbw| 欧美在线影院| 亚洲精品国久久99热| 色婷婷精品久久二区二区蜜臂av| 国产精品乡下勾搭老头1| 国产日韩欧美精品综合| 中文字幕日韩欧美一区二区三区| 久久国产精品一区二区三区| 国内精品久久久久影院色| 精品99一区二区| 亚洲午夜精品国产| 视频一区中文字幕| 在线播放国产精品二区一二区四区| 99国产欧美另类久久久精品 | 欧美喷潮久久久xxxxx| 国产成人h网站| 国产精品毛片无遮挡高清| 亚久久调教视频| 国产精品一级黄| 国产精品久久精品日日| 久久久综合香蕉尹人综合网| 丁香六月综合激情| 日韩一区欧美小说| 欧美性猛交xxxxxxxx| 99精品在线免费| 亚洲黄色av一区| 884aa四虎影成人精品一区| 国产精品大片| 日本免费在线视频不卡一不卡二| 日韩一区二区三区四区| 亚洲激情女人| 精品夜夜嗨av一区二区三区| 国产欧美日产一区| 日本韩国一区二区| 欧美+日本+国产+在线a∨观看| 午夜精品在线看| 久久久一区二区三区| 久久久久.com| 欧美 日韩 国产在线| 日韩av一区二区三区四区| 久久精品水蜜桃av综合天堂| 麻豆成人av| 99热99精品| 视频一区二区三区中文字幕| 久久久久国色av免费看影院| 久久av一区二区| 不卡欧美aaaaa| 午夜精品福利一区二区三区蜜桃| 精品国精品国产| 免费在线播放第一区高清av| 91最新地址在线播放| 日本欧美一区二区| 国产精品国产三级国产| 欧美二区三区的天堂| 99综合在线| 99re这里只有精品视频首页| 天堂va蜜桃一区二区三区| 国产区在线观看成人精品 | 丝袜亚洲另类欧美| 国产日韩三级在线| 欧美无砖砖区免费| 亚洲巨乳在线| 99这里只有精品| 国产精品婷婷| 欧美日韩国产在线一区| 国产一区在线看| 一区二区三区欧美日| 精品伦理精品一区| 欧美亚洲国产bt| 国产欧美短视频| 欧美在线视屏| 激情五月激情综合网| 亚洲一区二区三区视频在线播放 | 亚洲精品在线一区二区| 91久久免费观看| 亚洲国产专区| av在线播放不卡| 韩国成人在线视频| 丝袜国产日韩另类美女| 成人免费在线播放视频| 欧美午夜一区二区| 久久av一区二区三区| 在线播放一区| 午夜精品网站| 丁香六月综合激情| 日本成人超碰在线观看| 亚洲欧美一区二区三区孕妇| 26uuuu精品一区二区| 欧美日韩一区不卡| 久久精品中文| 日韩亚洲不卡在线| 国户精品久久久久久久久久久不卡| 顶级嫩模精品视频在线看| 青青草97国产精品免费观看无弹窗版| 亚洲激情成人在线| 国产精品激情偷乱一区二区∴| 精品国免费一区二区三区| 欧美一区国产二区| 欧美日韩一区三区四区| 色婷婷狠狠综合| 99热这里只有成人精品国产| 欧美另类亚洲| 牛人盗摄一区二区三区视频| 成人午夜免费av| 国产九九视频一区二区三区| 蜜臀av一区二区在线观看| 久久亚洲综合av| 精品免费日韩av| 欧美不卡一区二区三区| 欧美一区二区福利在线| 欧美日韩国产经典色站一区二区三区| 色狠狠一区二区三区香蕉| 久久久xxx| 久久不射2019中文字幕| 亚洲免费网址| 国产日韩一区二区三区| 日韩视频不卡| 99视频+国产日韩欧美| 亚洲黄色影片| 一本色道久久综合一区| 亚洲女性喷水在线观看一区| 国产精品二区一区二区aⅴ污介绍| 中文字幕av在线一区二区三区| 日本一区二区三区在线观看| 欧美激情在线免费观看| 国产精品日产欧美久久久久| 中文字幕av一区 二区| 中文字幕在线播放不卡一区| 亚洲天堂免费在线观看视频| 亚洲视频一区二区在线| 亚洲美女视频在线观看| 亚洲一区二区欧美激情| 亚洲成av人片| 免费成人在线影院| 精品一区二区三区影院在线午夜 | 亚洲成人自拍网| 五月婷婷色综合| 人人狠狠综合久久亚洲| 久国产精品韩国三级视频| 国产一区三区三区| 成人午夜精品在线| 不卡的电影网站| 欧美在线网站| 亚洲精品1区| 久久久久国产精品一区二区 | 欧美激情一区二区三区在线视频| 黄色亚洲免费| 亚洲一区图片|