自动化办公03 用xlrd和xlwt库操作excel.xls文件(老版本)

news2024/11/22 18:27:02

目录

一、读操作

二、写操作

三、设置单元格格式 

0.综合案例

 1.设置行高和列宽

2.设置字体样式

3.设置边框样式

 4.设置对齐方式

5.设置背景颜色

6.合并单元格 

 四、 xlutils修改Excel⽂件内容

1.安装

2.使用


一、读操作

import xlrd

# 1. 打开excel文件
wb = xlrd.open_workbook('files/data1.xls')

# 2. 获取工作簿相关信息
# 1)获取所有工作表的表名
names = wb.sheet_names()
print(names)

# 2)获取所有工作表
all_sheet = wb.sheets()
print(all_sheet)

# 3)获取一个工作表
# a.根据工作表的名字获取工作表
stu_sheet = wb.sheet_by_name('students')
print(stu_sheet)

# b.根据工作表的位置获取工作表
teacher_sheet = wb.sheet_by_index(1)
print(teacher_sheet)


# 3. 获取工作表相关信息
# 1)获取数据的行数和列数
m_r = stu_sheet.nrows
m_c = stu_sheet.ncols
print(m_r, m_c)

# 2) 获取某一个单元格
# 工作表对象.cell(行索引, 列索引)
cell1 = stu_sheet.cell(0, 0)
print(cell1)

# 3)获取某一个单元格内容
value1 = stu_sheet.cell_value(0, 0)
print(value1)

# 4) 获取某一行所有的单元格
line_cell = stu_sheet.row(1)
print(line_cell)

# 5) 获取某一行所有的内容
# a.工作表对象.row_values(行索引)  -  获取指定行中所有的内容
line_value1 = stu_sheet.row_values(1)
print(line_value1)

# b.工作表对象.row_values(行索引, 开始列下标, 结束列下标)  -  对指定行所有的内容进行切片
line_value2 = stu_sheet.row_values(1, 1)
print(line_value2)

line_value3 = stu_sheet.row_values(1, 0, 3)
print(line_value3)

print('~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~华~丽~丽~的~分~割~线~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~')
# 工作表对象.col_values(列索引)
col_value1 = stu_sheet.col_values(3)
print(col_value1)

scores = stu_sheet.col_values(3, 1)
print(scores)

练习1:

# 练习:获取data1.xls文件中students表中的所有学生信息,以列表的形式返回,每个学生信息对应一个小列表。
wb = xlrd.open_workbook('files/data1.xls')
sheet = wb.sheet_by_name('students')

m_r = sheet.nrows
students1 = []
for line in range(1, m_r):
    stu = sheet.row_values(line)
    students1.append(stu)
print(students1)

 

练习2:

# 练习:获取data1.xls文件中students表中的所有学生信息,以列表的形式返回,每个学生信息对应一个小字典。
students2 = []
m_r = sheet.nrows
m_c = sheet.ncols
key = sheet.row_values(0)
for line in range(1, m_r):
    dic = {}
    stu = sheet.row_values(line)
    for x in range(m_c):
        dic[key[x]] = stu[x]
    students2.append(dic)
print(students2)

二、写操作

注意:xlwt只能对通过xlwt新建的文件和工作表进行写操作 

# 注意:xlwt只能对通过xlwt新建的文件和工作表进行写操作。
import xlwt

# 1.新建excel文件(新建一个工作簿)
# 注意:新建工作簿的时候不会自动创建工作表
wb = xlwt.Workbook()

# 2. 添加工作表
sheet1 = wb.add_sheet('订单数据')

# 3. 修改单元格内容
# 工作表对象.write(行索引, 列索引, 内容)  -  将指定内容写入到指定的位置
sheet1.write(1, 0, '你好')

# 保存文件
wb.save('files/data2.xls')

练习:

# 练习1:将data中的数据按照生活习惯写入到.xls文件中
data = [
    ['小明', '男', 20.0, 99.0],
    ['张三', '男', 25.0, 87.0],
    ['小花', '女', 22.0, 95.0],
    ['老王', '男', 30.0, 77.0]
]

wb = xlwt.Workbook()
sheet = wb.add_sheet('练习1')

label = ['姓名', '性别', '年龄', '分数']

row = len(data)
col = len(label)
# print(row,col)

for i in range(col):
    sheet.write(0, i, label[i])

for x_row in range(0, row):
    for y_col in range(col):
        sheet.write(x_row + 1, y_col, data[x_row][y_col])

wb.save('files/写练习1.xls')

 

三、设置单元格格式 

0.综合案例

import xlwt

# 1. 新建文件和工作表
wb = xlwt.Workbook()
sheet = wb.add_sheet('样式')

# 2.设置行高和列宽
# 1)设置列宽
sheet.col(1).width = 20 * 256

# 2)设置行高
# a.让行高不匹配内容的高度
sheet.row(2).height_mismatch = True
# b.设置行高为指定值
sheet.row(2).height = 15 * 60

# 3. 写入数据的时候设置单元格的样式
# 1)创建样式对象
style1 = xlwt.XFStyle()

# 2)给样式对象绑定具体的样式内容
# a. 字体相关样式
# 创建一个字体对象
font1 = xlwt.Font()
# 将字体绑定到样式对象中
style1.font = font1
# 添加各种字体属实
font1.name = '楷体'           # 字体名称
font1.colour_index = 10         # 字体颜色
# 打印所有的颜色和其对应的编号(xlwt中可以使用的所有颜色)
# print(xlwt.Style.colour_map)

font1.height = 20*20        # 字体大小
font1.bold = True       # 字体加粗

# b.设置对齐样式
# 创建一个对齐对象
ag1 = xlwt.Alignment()
# 将对齐对象绑定到样式对象中
style1.alignment = ag1
# 添加各种对齐属性
ag1.horz = xlwt.Alignment.HORZ_CENTER       # 水平居中
ag1.vert = xlwt.Alignment.VERT_CENTER       # 垂直居中

# c. 边框样式
# 创建一个边框对象
border1 = xlwt.Borders()
# 将边框对象绑定到样式对象中
style1.borders = border1
# 添加各种边框属性
border1.bottom = border1.top = 10
border1.bottom_colour = border1.top_colour = 57
border1.left = border1.right = 2
border1.left_colour = border1.right_colour = 46

# d. 填充样式
# 创建一个填充对象
p1 = xlwt.Pattern()
# 将填充对象绑定到样式对象中
style1.pattern = p1
# 添加填充属性
p1.pattern = xlwt.Pattern.SOLID_PATTERN
p1.pattern_fore_colour = 31


# 3)在写入数据的指定样式对象
sheet.write(2, 1, 'hello', style=style1)
sheet.write(2, 2, '你好', style=style1)


wb.save('files/data4.xls')

 1.设置行高和列宽

案例:

fruits_s.col(0).width = 30 * 256
fruits_s.row(0).height_mismatch = True
fruits_s.row(0).height = 10 * 60
wb.save('files/data2.xls')

2.设置字体样式

常⻅的字体属性和对应的赋值⽅式如下:

 具体用法:

# 1. 创建样式对象
style1 = xlwt.XFStyle()
# 2. 创建字体对象
font = xlwt.Font()
# 3.将字体对象和样式对象进⾏关联
style1.font = font
# 4. 设置各种字体样式
font.name = '⿊体'
font.bold = True
font.height = 25 * 25
font.underline = xlwt.Font.UNDERLINE_SINGLE
font.escapement = xlwt.Font.ESCAPEMENT_SUPERSCRIPT
font.italic = True
font.colour_index = 52
font.struck_out = True
# 5. 写⼊内容的时候设置样式
fruits_s.write(1, 0, '苹果', style=style1)

打印xlwt.Style.colour_map可以查看所有可⽤的颜⾊: 

print(xlwt.Style.colour_map)

 

除了字体颜⾊,设置边框颜⾊、填充颜⾊都是使⽤colour_map中 提供的颜⾊值。

3.设置边框样式

设置边框样式分为四个⽅向,每个⽅向可以设置边框的类型和边框颜⾊:

具体用法:

# 1. 创建样式对象
style2 = xlwt.XFStyle()
# 2. 创建边框对象
borders1 = xlwt.Borders()
# 3. 设置样式对应的边框
style2.borders = borders1
# 4. 设置四个边的边框样式和边框样式
borders1.top, borders1.top_colour = 5, 12
borders1.bottom, borders1.bottom_colour = 8, 51
borders1.left, borders1.left_colour = 9, 17
borders1.right, borders1.right_colour = 13, 10
# 5. 写⼊内容的时候设置样式
fruits_s.write(3, 1, '¥30.00', style=style2)

 4.设置对齐方式

对⻬⽅式常⻅属性如下:

具体用法:
 

style3 = xlwt.XFStyle()
alignment1 = xlwt.Alignment()
style3.alignment = alignment1
alignment1.vert = xlwt.Alignment.VERT_CENTER
alignment1.horz = xlwt.Alignment.HORZ_CENTER
alignment1.rota = 45
# alignment1.wrap = 1 # ⾃动换⾏
# alignment1.shri = 1 # ⾃动缩进
fruits_s.write(1, 4, '对⻬⽅式', style=style3)

5.设置背景颜色

# 1. 创建样式对象
style4 = xlwt.XFStyle()
# 2. 创建模式对象
pattern1 = xlwt.Pattern() 
# 3. 将模式关联到样式中
style4.pattern = pattern1
pattern1.pattern = xlwt.Pattern.SOLID_PATTERN # 设置模式
pattern1.pattern_fore_colour = xlwt.Style.colour_map['yellow'] # 设置填充颜
⾊
fruits_s.write(2, 0, '草莓', style=style4)

6.合并单元格 

写⼊数据的时候可以通过write_merge⽅法在写⼊数据的同时合并单元格。

语法:

⼯作表对象.write_merge(r1, r2, c1, c2, 写⼊内容, 样式) 

r1,r2合并的起始⾏和终⽌⾏,c1,c2合并的起始列和终⽌列 

案例:

fruits_s. write_merge(8, 10, 3, 5, '合并单元格')

 

 四、 xlutils修改Excel⽂件内容

xlwt⽆法对已经存在的Excel⽂件进⾏写操作,如果要修改已经存在的Excel⽂件中的内容需要使
⽤xlutils模块。
xlutils的使⽤原理是:先通过xlrd打开⼀个Excel⽂件得到⼀个⼯作簿对象,然后通过xlutils对⼯作簿对象进⾏拷⻉就可以得到⼀个可写的⼯作簿对象,最后就可以对可的⼯作簿进⾏写操作和保存操作。 

1.安装

pip install xlutils

2.使用

from xlutils.copy import copy
import xlrd
# 1. 打开原⽂件
old_wb = xlrd.open_workbook('files/data1.xls', formatting_info=True)
# 2. 拷⻉原⽂件得到可写的⼯作簿对象
new_wb = copy(old_wb)
# 3. 添加⼯作表
s1 = new_wb.add_sheet('data')
# 4. 写⼊数据
s1.write(0, 0, '数据1')
new_wb.save('files/new_data1.xls')

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1818826.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MT7981B+MT7976C+MT7531A RF定频测试方法

1、从下面网址下载QA软件包,然后在WIN系统下安装QA环境。 https://download.csdn.net/download/zhouwu_linux/89428691?spm1001.2014.3001.5501 在WINDOWS 7系统下先安装WinPcap_4_1_3.exe。 2、搭建硬件环境,电脑先连接仪器,主板网络与电…

Deepstream用户手册——DeepStream应用及配置文件

DeepStream参考应用 - DeepStream-app 应用架构 下图显示了NVIDIADeepStream参考应用程序的架构。 DeepStream 参考应用程序是一个基于 GStreamer 的解决方案,由一组封装低级 API 以形成完整图形的GStreamer插件组成。参考应用程序能够接受来自各种来源的输入&…

算法day28

第一题 295. 数据流的中位数 本题我们是求解给定数组的中位数。且由于需要随时给数组添加元素,所以我们要求解该动态数组的中位数,所以本题最关键的就是维护数组在添加元素之后保持有序的排序,这样就能很快的求解中位数; 解法&am…

提升消费者满意度的五星售后服务认证

在当今竞争激烈的市场环境中,消费者满意度是企业取得成功的重要因素。五星售后服务认证作为一种权威性认证,可以显著提高消费者满意度,增强企业的竞争力。本文将从四个方面探讨五星售后服务认证如何提高消费者满意度。 五星售后服务认证是由国…

RedHat9 | iSCSI磁盘配置与管理

一、实验环境 1、iSCSI介绍 iSCSI(Internet Small Computer System Interface)是一种基于因特网及SCSI-3协议下的存储技术,也称为IP-SAN。iSCSI是由IETF(Internet Engineering Task Force)提出,并于2003年…

wms海外仓系统有哪些?选择的时候怎么避坑

虽然说wms海外仓系统能够在很大程度上提升海外仓的经营效率,但是如果在选择wms海外仓系统的时候没有慎重考虑,也是非常容易踩坑的。 这样不只是不能提升自己海外仓的效率,反倒是浪费了大量的预算和精力,这就得不偿失了。今天我们…

检查子树00

题目链接 检查子树 题目描述 注意点 树的节点数目范围为[0, 20000] 解答思路 递归判断t1和t2的val是否相同,如果相同,则继续递归判断其左右子树的值是否都相同,如果都相同则返回true;如果不相同,则继续递归判断t1…

剧本新纪元:探索短剧系统的魔力

在现代社会,随着科技的迅猛进步和生活节奏的不断加快,传统的长篇电视剧和电影已不能完全满足所有人的需求。短剧,由于其简短、快速、直接的特性,正在逐步成为一种文化新趋势。短剧系统正是这一趋势的典型代表,它以独特…

tracetcp下载 安装 使用 网络工具 windows trace工具 tcp协议

省流 Tracetcp是一个类似于Tracert的工具,使用如下: 1. 安装winpcap , 下载链接:WinPcap Download 2.下载tracetcp软件,下载链接: https://github.com/0xcafed00d/tracetcp/releases 命令:…

如何学习软件测试,并成功找到工作

在IT行业日益繁荣的今天,软件测试作为确保软件质量的关键环节,越来越受到企业的重视。对于初入职场的小白来说,掌握软件测试技能不仅能够帮助他们快速适应工作,还能为未来的职业发展奠定坚实的基础。本文将为职场小白推荐学习软件…

如何翻译和本地化游戏?翻译访谈

如何翻译和本地化游戏?这个过程的技术细节有哪些?游戏翻译不同于电影翻译。Logrus IT游戏本地化部门负责人阿列克谢费奥多罗夫(Alexey Fedorov)在接受RUDN语言学系外语系教授和研究人员的采访时谈到了这一点,他是由尤利…

一、JAVA性能调优之linux命令工具

一、linux性能收集和统计工具 二、JAVA性能调优之jdk命令工具 一、linux性能收集和统计工具 linux在性能遇到问题时,常用的查看分析命令有 top:能够实时显示系统各个进程的资源占用情况;sar:可以周期性的对内存CPU使用情况采样…

现货黄金投资价格怎么分析 低买高卖是核心!

我们做现货黄金投资,总是离不开对黄金价格的分析,分析其实就是一种理性的思考,我们对现货黄金当前走势进行一番思考,进而判断它未来的走向,以此作为自己投资入场的基础。那黄金投资价格怎么分析呢?下面我们…

MySQL 核心模块揭秘 | 20 期 | MySQL 怎么加表锁?

意向共享锁、意向排他锁、AUTO-INC 锁是 InnoDB 最常用的表锁,它们的加锁流程是什么样的? 作者:操盛春,爱可生技术专家,公众号『一树一溪』作者,专注于研究 MySQL 和 OceanBase 源码。 爱可生开源社区出品&…

Ecahrts横向柱状图自动滚动

1.定义一个定时器标识 let timer: NodeJS.Timer; // 定时器 2.定义展示的数据的条数 const dataZoomEndValue 5; // 数据窗口范围的结束数值(一次性展示几个) 3.设置datazoom的相关参数 dataZoom: [{show: false, // 是否显示滑动条xAxisIndex: 0, // 表示从X轴的零刻度线…

植物大战僵尸杂交版 MacBook 苹果电脑下载安装详细教程

最近老是看到别人玩植物大战僵尸杂交版,可是找了一圈发现都是PC版本的,原来游戏作者只做了一个PC版本,还好最终没有放弃终于在 Mac 上安装上了植物大战僵尸杂交版 版本是 2.0.88 真的蛮好玩的就是关卡有亿点点难,我最爱玩无尽模式…

四川赤橙宏海商务信息咨询有限公司靠谱吗?

在数字化浪潮席卷而来的今天,电商行业正经历着前所未有的变革。四川赤橙宏海商务信息咨询有限公司,凭借其深厚的行业经验和敏锐的市场洞察力,专注于抖音电商服务领域,致力于为广大商家提供全方位、高效益的电商解决方案。 赤橙宏…

闪烁圆点加载动画

效果图: 完整代码: <!DOCTYPE html> <html> <head><meta charset="UTF-8" /><title>闪烁圆点加载动画</title><style type="text/css">body {background: #ECF0F1;display: flex;justify-content: center;al…

Linux部署mysql8.0.28数据库

目录 1.基础准备 (1)首先去官网下载二进制安装包 (2)下载好之后上传至服务器 (3)禁用关闭selinux和防火墙 (4)挂载光盘搭建本地yum仓库 2.解压到指定目录 3.检查系统是否安装mariadb 4.安装MySQL数据库 (1)进入MySQL目录 看到‘完毕’就说面mysql已经安装成功了 4.初…

易基因:【表观遗传学基础】如何研究DNA甲基化

大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。 表观遗传学近几年取得的一系列研究进展&#xff0c;确实吸引着越来越多的关注&#xff01;为了帮大伙儿梳理一下表观遗传学的基本概念和研究方法&#xff0c;小编打算开一个系列专题&…