Python如何实现Excel的最合适列宽(openpyxl)
作者:chaodaibing 发布时间:2023-07-23 04:06:04
标签:Python,Excel,列宽,openpyxl
Excel的最合适列宽(openpyxl)
Python的Pandas模块是处理Excel的利器,尤其是加工保存Excel非常方便,但是唯独想让导出的Excel自动调整列宽或者行高,确实做不到啊,尤其是加工后还需要使用者自己调整列宽,非常不便。
所以必须openpyxl模块助力。
这是最简单的实现
from openpyxl import load_workbook
wb = load_workbook('test.xlsx')
ws = wb[wb.sheetnames[0]] # 打开第一个sheet
ws.column_dimensions['A'].width = 20.0 # 调整列A宽
ws.row_dimensions[1].height = 40 # 调整行1高
ws.save('test.xlsx')
但是如果随便让 一个Excel每个sheet都实现调整列宽怎么办呢,我写了这么一个函数
获取每一个sheet的每一列的最长值,将其设置为列宽
from openpyxl import load_workbook
from openpyxl.utils import get_column_letter
def reset_col(filename):
wb=load_workbook(filename)
for sheet in wb.sheetnames:
ws=wb[sheet]
df=pd.read_excel(filename,sheet).fillna('-')
df.loc[len(df)]=list(df.columns)#把标题行附加到最后一行
for col in df.columns:
index=list(df.columns).index(col)#列序号
letter=get_column_letter(index+1)#列字母
collen=df[col].apply(lambda x:len(str(x).encode())).max()#获取这一列长度的最大值 当然也可以用min获取最小值 mean获取平均值
ws.column_dimensions[letter].width=collen*1.2+4#也就是列宽为最大长度*1.2 可以自己调整
wb.save(filename)
reset_col('test.xlsx')
注意Openpyxl仅仅支持最新的.xlsx格式,如果执行有这样的报错:
File “C:\Users\Administrator\AppData\Local\Programs\Python\Python38\lib\site-packages\openpyxl\reader\excel.py”, line 94, in _validate_archive raise InvalidFileException(msg) openpyxl.utils.exceptions.InvalidFileException: openpyxl does not support the old .xls file format, please use xlrd to read this file, or convert
说明文件格式老旧,请打开Excel文件,选择另存为.xlsx格式
Python写Excel列宽,行高的一些方法
使用第三方库 xlsxwriter,结果文件格式为xlsx
代码如下:
import xlsxwriter
# 创建一个新工作簿并添加一个工作表。
workbook = xlsxwriter.Workbook(r'\\Mac\Home\Desktop\test11.xlsx')
worksheet = workbook.add_worksheet('test')
# 为第一列设置格式
worksheet.set_column('A:A', 30) # 设置A列宽度30
worksheet.set_column('B:B', 20) # 设置B列宽度20
# cell_format = workbook.add_format({'bold': True})
worksheet.set_row(3, 20) # 设置第4行高度为20
# worksheet.set_row(3, 20,cell_format)
实现结果截图如下:
使用第三方库 xlwt,结果文件格式为xls
代码如下:
import xlwt
book = xlwt.Workbook(r'\\Mac\Home\Desktop\test22.xls')
sheet = book.add_sheet('sheet1')
first_col=sheet.col(0)
sec_col=sheet.col(1)
first_col.width=256*20 # 宽度
tall_style = xlwt.easyxf('font:height 720;') # 36pt,类型小初的字号
first_row = sheet.row(0)
first_row.set_style(tall_style)
book.save(r'\\Mac\Home\Desktop\test22.xls')
参数解释:
'''
xlwt中列宽的值表示方法:默认字体0的1/256为衡量单位。
xlwt创建时使用的默认宽度为2960,既11个字符0的宽度
所以我们在设置列宽时可以用如下方法:
width = 256 * 20 256为衡量单位,20表示20个字符宽度
'''
实现结果截图如下:
来源:https://blog.csdn.net/chaodaibing/article/details/106695798
0
投稿
猜你喜欢
- 加了三个验证漏洞以及四个getshell方法# /usr/bin/env python3# -*- coding: utf-8 -*-# @
- 在进行python数据分析的时候,首先要进行数据预处理。有时候不得不处理一些非数值类别的数据,嗯, 今天要说的就是面对这些数据该如何处理。目
- 1、应该将 CSS 放置于结构的上方(一般放置于 head 元素内)。CSS 是解释型语言,Firefox 和 IE 在等待 CSS 传输完
- 1.列表(List)元组是由一对方括号构成的序列。列表创建后,可以根据自己的需要改变他的内容>>> list=[1,2,3
- 本文分享的实例主要实现的是Python+matplotlib绘制一个有阴影和没有阴影的3D条形图,具体如下。首先看看演示效果:完整代码如下:
- 代码如下: Function NumberSplit(num) Dim i,length length=Len(num) For i=1 T
- Server对象主要是给编程人员提供一些方便的对象和属性。(1)ScriptTimeout属性:<%Server.ScriptTime
- 前言:python由于GIL(全局锁)的存在,不能发挥多核的优势,其性能一直饱受诟病。然而在IO密集型的网络编程里,异步处理比同步处理能提升
- 前言近几年,制造业作为国民经济主体,是国家创造力、竞争力和综合国力的重要体现。作为制造强国建设的主攻方向,可以说,智能制造发展水平关乎我国未
- 有一道算法题题目的意思是在二维数组里找到一个峰值。要求复杂度为n。解题思路是找田字(四边和中间横竖两行)中最大值,用分治法递归下一个象限的田
- 什么是 docopt?1、docopt 是一种 Python 编写的命令行执行脚本的交互语言。它是一种语言!它是一种语言!它是一种语言!2、
- 如果您的网站面向世界各地的冲浪者或者对外开展商贸活动,检测来访者的浏览器语言类型就非常现实了。这里提供的脚本可以检测流露;浏览器
- 问题:最新在爬取某站点的时候,发现在post请求当中,参数构造正确却获取不到数据,索性将post的参数urlencode之后放到post请求
- 前言编写条件分支代码是编码过程中不可或缺的一部分。如果用道路来做比喻,现实世界中的代码从来都不是一条笔直的高速公路,而更像是由无数个岔路口组
- format是字符串内嵌的一个方法,用于格式化字符串。以大括号{}来标明被替换的字符串。1、基本用法1. 按照{}的顺序依次匹配括号中的值s
- 摘要: Portal是IT领域的新技术,是企业信息化工作的发展方向之一。本文首先介绍了Oracle Portal的定义、特点,接着阐述了po
- 我最近在涉及大量数据处理的项目中频繁使用 sqlite3。我最初的尝试根本不涉及任何数据库,所有的数据都将保存在内存中,包括字典查找、迭代和
- 有很多时候,我们会在python的运行过程中得到一些重要的变量,比如一个数据量很庞大的dict。而且,后面的某些程序也会用到这个dict,那
- 1. self, cls 不是关键字 在python里面,self, cls 不是关键字,完全可以使用自己写的任意变量代替实现一样的效果 代
- 起因修改了表结构以后执行python3 manage.py migrate 报错:django.db.utils.OperationalEr