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

目录

一、读操作

二、写操作

三、设置单元格格式 

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.rhkb.cn/news/348624.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

电脑蓝屏怎么办?7个方法为你解决问题!

“我今天开电脑时,不知道为什么电脑突然就蓝屏了。大家有什么方法可以解决电脑蓝屏问题吗?” 在现代社会的快节奏中,电脑已经成为了我们工作和生活的重要伙伴。然而,当这个“伙伴”突然展现出它的“任性”一面——蓝屏时&#xff…

焦化行业排放平台简介

在当今社会,环保事业日益受到人们的关注。焦化行业作为重要的工业领域之一,其排放问题一直是环保工作的重点。为了有效控制焦化行业的排放,实施焦化行业排放平台成为了必不可少的措施。朗观视觉小编将详细探讨焦化行业排放平台的实施范围&…

MySQL之高级特性(三)

高级特性 分布式(XA)事务 存储引擎的事务特性能够保证在存储引擎级别实现ACID,而分布式事务则让存储引擎级别的ACID可以扩展到数据库层面,甚至可以扩展到多个数据库之间——这需要通过两阶段提交实现。MySQL5.0和更新版本的数据库已经开始支持XA事务了。XA事务中需…

最短路径Bellman-Ford算法和SPFA算法详解

目录 Bellman-Ford算法介绍 Bellman-Ford算法证明 Bellman-Ford算法实现 SPFA算法详解 Bellman-Ford算法介绍 Dijkstra算法可以很好的解决无负权图的最短路径问题,但是如果出现了负权边,Dijkstra算法就会失效。为了更好地求解有负权边的最短路径问…

第 5 章:面向生产的 Spring Boot

在 4.1.2 节中,我们介绍了 Spring Boot 的四大核心组成部分,第 4 章主要介绍了其中的起步依赖与自动配置,本章将重点介绍 Spring Boot Actuator,包括如何通过 Actuator 提供的各种端点(endpoint)了解系统的…

STM32程序启动过程

(1)首先对栈和堆的大小进行定义,并在代码区的起始处建立中断向量表,其第一个表项是栈顶地址(32位),第二个表项是复位中断服务入口地址; (2)然后执行复位中断&…

人工智能AI概览

1、达特茅斯会议 2、人工智能元老 3、人工智能发展史 4、符号主义 5、连接主义 6、行为主义 7、三大学派优劣分析 8、人工智能 9、人工智能层次结构 10、机器学习、深度学习 11、人工智能现状 12、人工智能未来

HTML列表和表格标签

目录 1.列表标签 1.1无序列表 1.2有序列表 1.3定义列表 2. 表格标签、 2.1表格标签的属性 2.2合并单元格 1.列表标签 1.1无序列表 <ul>: [type 属性&#xff1a; disc( 实心圆点 )( 默认 ) 、 circle( 空心圆圈 ) 、 square( 实心方块 )] <li>: 列表中…

在VSCode中安装python

引言 Python 是一种广泛使用的高级编程语言&#xff0c;因其易学、易用、强大而受到欢迎。它由 Guido van Rossum 于 1991 年首次发布&#xff0c;并以简洁的语法和丰富的库生态系统而著称。 以下是 Python 的一些关键特点和优势&#xff1a; 关键特点 易于学习和使用&#x…

SolidWorks对设计电脑硬件配置要求是怎么样的

SolidWorks&#xff0c;作为达索系统&#xff08;Dassault Systemes&#xff09;旗下的子公司&#xff0c;一直以其出色的机械设计软件解决方案而著称。它是基于Parasolid内核开发&#xff0c;是单核三维设计软件&#xff0c;面上使用比较多的版本有SolidWorks2022、SolidWorks…

Java 数据类型 -- Java 语言的 8 种基本数据类型、字符串与数组

大家好&#xff0c;我是栗筝i&#xff0c;这篇文章是我的 “栗筝i 的 Java 技术栈” 专栏的第 004 篇文章&#xff0c;在 “栗筝i 的 Java 技术栈” 这个专栏中我会持续为大家更新 Java 技术相关全套技术栈内容。专栏的主要目标是已经有一定 Java 开发经验&#xff0c;并希望进…

6.每日LeetCode-数组类,找到所有数组中消失的数字(Go)

题目 448找到所有数组中消失的数字.go 给你一个含 n 个整数的数组 nums &#xff0c;其中 nums[i] 在区间 [1, n] 内。请你找出所有在 [1, n] 范围内但没有出现在 nums 中的数字&#xff0c;并以数组的形式返回结果。 示例 1&#xff1a; 输入&#xff1a;nums [4,3,2,7,8,2,…

MySQL 8.0 安装、配置、启动、登录、连接、卸载教程

目录 前言1. 安装 MySQL 8.01.1 下载 MySQL 8.01.2 安装 MySQL 8.0 2. 配置 MySQL 8.02.1打开环境变量2.2新建变量 MYSQL_HOME2.3编辑 Path 变量 3. 启动MySQL 8.03.1验证安装与配置是否成功3.2初始化并注册MYSQL3.3 启动MYSQL服务 4.登录MySQL4.1修改账户默认密码4.2登录MYSQL…

基于springboot实现小型诊疗预约平台系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现小型诊疗预约平台系统的设计演示 摘要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本小型诊疗预约平台就是在这样的大环境下诞生&#xff0c…

西安交通大学联合中科院半导体所通过龙讯旷腾PWmat发表最新《iScience》:固定电势法揭示质子转移过程中的电子转移之谜

电化学是研究电能和化学能之间相互转换的科学。在能源日趋紧张的今天&#xff0c;研究电化学中的能量转换特性对能源科学的进步具有深远的意义。电子是电能的载体&#xff0c;因此研究电子在电化学过程中的转移是加深对电化学反应能量交换机制理解的关键。以质子电化学还原反应…

架构设计 - nginx 的核心机制与主要应用场景

一、nginx 的核心机制&#xff1a; 1. 事件驱动模型&#xff08;epoll 多路复用&#xff09; 事件循环&#xff1a; Nginx的核心组件是一个事件循环&#xff0c;它不断地监听事件&#xff08;如新连接的到来、请求数据的可读性等&#xff09;。 当有事件发生时&#xff0c;事…

深入解析TF-IDF算法:文本分析的基石与力量

在信息爆炸的时代文本数据无处不在&#xff0c;从新闻报道到社交媒体帖子&#xff0c;从学术论文到产品评论&#xff0c;大量的文本信息需要被有效地分析和利用。在这样的背景下TF-IDF&#xff08;Term Frequency-Inverse Document Frequency&#xff09;算法作为一种简单而有效…

【动态规划算法题记录】70. 爬楼梯——递归/动态规划

题目描述 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢&#xff1f; 题目分析 递归法&#xff08;超出时间限制&#xff09; 递归参数与返回值 void reversal(int i, int k) 每次我们处理第i个台阶到第k个…

redis 一些笔记1

redis 一、redis事务二、管道2.1 事务与管道的区别 三、主从复制3.13.2 权限细节3.3 基本操作命令3.4 常用3.4.1 一主几从3.4.2 薪火相传3.4.3 反客为主 3.5 步骤3.6 缺点 一、redis事务 放在一个队列里&#xff0c;依次执行&#xff0c;并不保证一致性。与mysql事务不同。 命…

一文讲清:bom管理系统是什么?在生产管理中有什么作用?

在制造业中&#xff0c;物料清单&#xff08;Bill of Materials&#xff0c;简称BOM&#xff09;扮演着至关重要的角色。物料清单&#xff08;BOM&#xff09;是制造或维修产品所需的材料、组件和零件的结构化综合列表&#xff0c;以及所需材料的数量、名称、描述和成本。简而言…