利用Python操作excel表格的完美指南
作者:运维家 发布时间:2022-05-21 07:59:09
标签:python,excel,表格
主旨
在日常工作中,我们会经常且频繁的使用excel表格,那么我们是否可以通过python来操作excel表格,让其自动化的来代替我们的工作呢?比如涉及到的居中、合并单元格、修改字体颜色等。
环境
linux 服务器一台,亦或者windows10电脑一台
python3.7.1版本,python3.x的都可以
安装模块
操作excel需要用到的模块是“xlwt”,我们需要使用python中的pip命令来安装此模块;
PS:centos默认的python是2.x版本,建议升级到python3.x版本,否则无法进行后续过程;可以参考这篇文章:https://www.jb51.net/article/207073.htm,即可查看具体安装过程;
[yunweijia@localhost jier]$ sudo pip3 install xlwt -i https://pypi.tuna.tsinghua.edu.cn/simple # 使用国内源下载xlwt模块
[yunweijia@localhost jier]$ sudo pip3 list # 查看下载结果
Package Version
---------- -------
pip 21.3.1
setuptools 39.0.1
xlwt 1.3.0
[yunweijia@localhost jier]$
新建excel
代码:
#coding:utf-8
#!/usr/local/python3/bin/python3
# 导入模块
import xlwt
# 新建一个excel
workbook = xlwt.Workbook(encoding='utf-8')
# 新建一个sheet,名字为“运维家”,可以创建多个sheet
worksheet = workbook.add_sheet('运维家')
# 保存excel,名字为“yunweijia”
workbook.save(str("yunweijia.xls"))
运行:
[yunweijia@localhost jier]$ python3 ceshi.py
[yunweijia@localhost jier]$ ls
ceshi.py yunweijia.xls
[yunweijia@localhost jier]$
结果:
单元格写入数据
代码:
#coding:utf-8
#!/usr/local/python3/bin/python3
# 导入模块
import xlwt
# 新建一个excel
workbook = xlwt.Workbook(encoding='utf-8')
# 新建一个sheet
worksheet = workbook.add_sheet('运维家')
# 在单元格中写入数据
worksheet.write(0, 0, "你好")
worksheet.write(0, 1, "我好")
worksheet.write(0, 2, "大家好")
worksheet.write(1, 1, "嘿嘿嘿")
# 保存excel
workbook.save(str("yunweijia.xls"))
运行:
[yunweijia@localhost jier]$ python3 ceshi.py
[yunweijia@localhost jier]$ ls
ceshi.py yunweijia.xls
[yunweijia@localhost jier]$
结果:
合并单元格
代码:
#coding:utf-8
#!/usr/local/python3/bin/python3
# 导入模块
import xlwt
# 新建一个excel
workbook = xlwt.Workbook(encoding='utf-8')
# 新建一个sheet
worksheet = workbook.add_sheet('运维家')
# 在单元格中写入数据
worksheet.write(0, 0, "你好")
worksheet.write(0, 1, "我好")
worksheet.write(0, 2, "大家好")
# 合并单元格(首单元格列,尾单元格列, 首单元格行, 尾单元格行)
worksheet.write_merge(1, 1, 0, 2, "嘿嘿嘿")
# 保存excel
workbook.save(str("yunweijia.xls"))
运行:
[yunweijia@localhost jier]$ python3 ceshi.py
[yunweijia@localhost jier]$ ls
ceshi.py yunweijia.xls
[yunweijia@localhost jier]$
结果:
居中显示
PS:可以根据实际情况创建多个样式,只要名字不一样即可;
代码:
#coding:utf-8
#!/usr/local/python3/bin/python3
# 导入模块
import xlwt
# 新建一个excel
workbook = xlwt.Workbook(encoding='utf-8')
# 新建一个sheet
worksheet = workbook.add_sheet('运维家')
# 创建一个样式
head_style = xlwt.XFStyle() # 创建样式
# 设置单元格对齐方式
ahead_lignment = xlwt.Alignment() # 对齐初始化
ahead_lignment.horz = xlwt.Alignment.HORZ_CENTER # 水平居中
ahead_lignment.vert = xlwt.Alignment.VERT_CENTER # 垂直居中
head_style.alignment = ahead_lignment # 样式重载
# 在单元格中写入数据
worksheet.write(0, 0, "你好")
worksheet.write(0, 1, "我好")
worksheet.write(0, 2, "大家好")
# 合并单元格(首单元格列,尾单元格列, 首单元格行, 尾单元格行)
worksheet.write_merge(1, 2, 0, 2, "嘿嘿嘿", head_style)
# 保存excel
workbook.save(str("yunweijia.xls"))
运行:
[yunweijia@localhost jier]$ python3 ceshi.py
[yunweijia@localhost jier]$ ls
ceshi.py yunweijia.xls
[yunweijia@localhost jier]$
结果:
修改字体和颜色
代码:
#coding:utf-8
#!/usr/local/python3/bin/python3
# 导入模块
import xlwt
# 新建一个excel
workbook = xlwt.Workbook(encoding='utf-8')
# 新建一个sheet
worksheet = workbook.add_sheet('运维家')
# 创建一个样式
head_style = xlwt.XFStyle() # 创建样式
# 创建字体
head_font = xlwt.Font() # 字体初始化
head_font.name = '楷体' # 字体
head_font.height = 300 # 大小
head_font.colour_index = 2 # 红色
head_style.font = head_font # 样式重载
# 设置单元格对齐方式
ahead_lignment = xlwt.Alignment() # 对齐初始化
ahead_lignment.horz = xlwt.Alignment.HORZ_CENTER # 水平居中
ahead_lignment.vert = xlwt.Alignment.VERT_CENTER # 垂直居中
head_style.alignment = ahead_lignment # 样式重载
# 在单元格中写入数据
worksheet.write(0, 0, "你好")
worksheet.write(0, 1, "我好")
worksheet.write(0, 2, "大家好")
# 合并单元格(首单元格列,尾单元格列, 首单元格行, 尾单元格行)
worksheet.write_merge(1, 2, 0, 2, "嘿嘿嘿", head_style)
# 保存excel
workbook.save(str("yunweijia.xls"))
运行:
[yunweijia@localhost jier]$ python3 ceshi.py
[yunweijia@localhost jier]$ ls
ceshi.py yunweijia.xls
[yunweijia@localhost jier]$
结果:
来源:https://blog.csdn.net/ouyangzhenxin/article/details/122754703
0
投稿
猜你喜欢
- 昨晚今晚写了两晚,总算把Py Port Scanner 写完了,姑且称之为0.1版本,算是一个Python多线程端口扫描工具。水平有限,实话
- YAHOO.util.Subscriber 与 YAHOO.util.CustomEvent。1. YAHOO
- 题目:给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。示例:示例 1:输入: “abcabcbb”输出: 3解释: 因为无重
- 项目需求:将kafka解析来的日志获取到数据库的变更记录,按照订单的级别和订单明细级别写入数据库,一条订单的所有信息包括各种维度信息均保存在
- 一直在用JS写ASP,也不是特别原因,只是当初学的是JS,后来学ASP时知道ASP也可以用JS写,就没去学VBS.前几个月刚学ASP的时候找
- 需求分析项目上需要用到手机号前7位,判断号码是否合法,还有归属地查询。旧的数据是几年前了太久了,打算用python爬虫重新爬一份单线程版本#
- list.asp<%@LANGUAGE="VBSCRIPT" CODEPAGE="936&qu
- 对于字典,通过“键”获得“值”非常简单,但通过“值”获得“键”则需绕些弯子。一、通用:自行定义函数方式假设:输入:一个字典(dic)+要找的
- 思路非常简单:<p>创建window,设置窗口大小,创建label1,导入图片,创建label2,导入文字,show,结束!&l
- 前言最近学习了 django 的一个 restframework 框架,对于里面的执行流程产生了兴趣,经过昨天一晚上初步搞清楚了执行流程(部
- 本文为Django项目创建的简单介绍,更为详细的Django项目创建,可以参考如下教程:Django入门与实践-https://www.jb
- 优化数据库的注意事项:1、关键字段建立索引。2、使用存储过程,它使SQL变得更加灵活和高效。3、备份数据库和清除垃圾数据。4、SQL语句语法
- 我们在用Python进行机器学习建模项目的时候,每个人都会有自己的一套项目文件管理的习惯,我自己也有一套方法,是自己曾经踩过的坑总结出来的,
- lambda函数是一种小的匿名函数。lambda语法lambda函数:lambda [arg1 [,arg2,...[,argn]]] :
- 本文实例总结了Python多进程并发与多线程并发。分享给大家供大家参考,具体如下:这里对python支持的几种并发方式进行简单的总结。Pyt
- 使用Python可视化Pygal包来生成可缩放的矢量图形文件!对于在尺寸不同的屏幕上显示图标,它们将自动缩放以适合观看者的屏幕,如果以在线的
- 主要代码如下: total = application("All
- Office家族成员中,人们对于Access 2000的了解,往往只局限在它的操作界面中,对于数据库管理的功能仍只是停留在建立表、数据输入、
- Windows环境: (1)离线安装 首先在线搜索并下载你需要的第三方库:网址https
- 具体环境:Ubuntu 14.04 Python 2.7.6 Django 1.7.1 Virtualenv name:test Nginx