自动化办公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.mzph.cn/web/26320.shtml

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

相关文章

Flarum 安装和使用教程

随着开源社区的日益繁荣,人们对社区品质的要求也越来越高。传统的 BBS 论坛模式已经难以满足现代用户对美观、便捷、互动性的需求。搭建一个现代化的高品质社区,成为许多网站管理者的迫切需求和共同挑战。 今天就给大家安利一款现代化的、优雅的开源论坛…

立创·天空星开发板-GD32F407VE-Timer

本文以 立创天空星开发板-GD32F407VET6-青春版 作为学习的板子,记录学习笔记。 立创天空星开发板-GD32F407VE-Timer 定时器基本定时器示例 定时器 定时器是嵌入式系统中常用的一种外设,它可以产生一定的时间间隔、延时、定时等功能,广泛应用于…

网络安全等级保护基本要求 第1部分:安全通用要求

基本要求 第三级 安全物理环境 物理位置选择 a) 机房场地应选择在具有防震、防风和防雨等能力的建筑内; b) 机房场地应避免设在建筑物的顶层或地下室,否则应加强防水和防潮措施 物理访问控制 a) 机房出入口应配置电子门禁系统,控制、鉴…

Java项目:100 springboot共享汽车管理系统

作者主页:舒克日记 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 项目介绍 本共享汽车管理系统有管理员和用户。 管理员功能有个人中心,用户管理,投放地区管理,汽车信息管理,汽车…

用 KV 缓存量化解锁长文本生成

很高兴和大家分享 Hugging Face 的一项新功能: KV 缓存量化 ,它能够把你的语言模型的速度提升到一个新水平。 太长不看版: KV 缓存量化可在最小化对生成质量的影响的条件下,减少 LLM 在长文本生成场景下的内存使用量,从而在内存效率和生成速度…

基于STM32和人工智能的智能交通管理系统

目录 引言环境准备智能交通管理系统基础代码实现:实现智能交通管理系统 4.1 数据采集模块4.2 数据处理与分析4.3 控制系统4.4 用户界面与数据可视化应用场景:智能交通管理与优化问题解决方案与优化收尾与总结 1. 引言 随着城市化进程的加快&#xff0…

算法第六天:力扣第977题有序数组的平方

一、977.有序数组的平方的链接与题目描述 977. 有序数组的平方的链接如下所示:https://leetcode.cn/problems/squares-of-a-sorted-array/description/https://leetcode.cn/problems/squares-of-a-sorted-array/description/ 给你一个按 非递减顺序 排序的整数数组…

【C++】STL中stack和queue(适配器版)的模拟实现

前言:在此之前我们讲到了stack和queue还有deque的常见的使用方法,并且也在数据结构的时候用C语言去实现过栈和队列,今天我们将进一步的用C去模拟实现stack和queue 💖 博主CSDN主页:卫卫卫的个人主页 💞 👉 …

vue 之 vuex

目录 vuex 是什么 Vuex管理哪些状态呢? Vuex 页面刷新数据丢失怎么解决 1. 使用浏览器的本地存储 2. 使用 Vuex 持久化插件 3. 使用后端存储 注意事项 Vuex 为什么要分模块并且加命名空间 vuex 是什么 vuex 是专门为 vue 提供的全局状态管理系统&#xff0c…

【应用案例】如何解决无人驾驶车辆的动力转向问题

埃尔朗根-纽伦堡大学名称为高能赛车运动队(High-Octane Motorsports e.V.)的学生方程式车队都设计、构建和制造具有创新意义且独特的赛车。然后,他们将参加三种不同类别的大学生方程式比赛;该项赛事中的参赛队伍来自于世界各地。 电动、无人驾驶和燃油车…

Windows 11 24H2版首发体验!附详细更新升级安装教程

Windows 11 24H2 版首发体验!这是微软2024年的大版本更新,新增超多新功能,以下会给你细细道来。这个版本目前小编亲测,使用非常流畅,没有什么明显问题。系统是已经集成了VB6/VC2005/VC2008/VC2010/VC2012/VC2013/VC201…

Dorkish:一款针对OSINT和网络侦查任务的Chrome扩展

关于Dorkish Dorkish是一款功能强大的Chrome扩展工具,该工具可以为广大研究人员在执行OSINT和网络侦查任务期间提供强大帮助。 一般来说,广大研究人员在执行网络侦查或进行OSINT信息收集任务过程中,通常会使用到Google Dorking和Shodan&…

2024年高考:计算机相关专业还值得选择吗?

🍎个人博客:个人主页 🏆个人专栏:日常聊聊 ⛳️ 功不唐捐,玉汝于成 目录 前言 正文 行业竞争现状 市场饱和与新兴技术的影响 如何保持竞争力 专业与个人的匹配度判断 专业核心课程与技术能力 个人兴趣与职业…

使用开源的zip.cpp和unzip.cpp实现压缩包的创建与解压(附源码)

目录 1、使用场景 2、压缩包的创建 3、压缩包的解压 4、CloseZipZ和CloseZipU两接口的区别 5、开源zip.cpp和unzip.cpp文件的下载 VC++常用功能开发汇总(专栏文章列表,欢迎订阅,持续更新...)https://blog.csdn.net/chenlycly/article/details/124272585C++软件异常排…

【C语音 || 数据结构】二叉树--堆

文章目录 前言堆1.1 二叉树的概念1.2 满二叉树和完美二叉树1.3 堆的概念1.4 堆的性质1.4 堆的实现1.4.1堆的向上调整算法1.4.1堆的向下调整算法1.4.1堆的接口实现1.4.1.1堆的初始化1.4.1.2堆的销毁1.4.1.3堆的插入1.4.1.4堆的删除1.4.1.4堆的判空1.4.1.4 获取堆的数据个数 前言…

单体架构改造为微服务架构之痛点解析

1.微服务职责划分之痛 1.1 痛点描述 微服务的难点在于无法对一些特定职责进行清晰划分,比如某个特定职责应该归属于服务A还是服务B? 1.2 为服务划分原则的痛点 1.2.1 根据存放主要数据的服务所在进行划分 比如一个能根据商品ID找出商品信息的接口,把…

随手记:uniapp图片展示,剩余的堆叠

UI效果图&#xff1a; 实现思路&#xff1a; 循环图片数组&#xff0c;只展示几张宽度就为几张图片边距的宽度&#xff0c;剩下的图片直接堆叠展示 点击预览的时候传入当前的下标&#xff0c;如果是点击堆叠的话&#xff0c;下标从堆叠数量开始计算 <template><…

pycharm基本使用(常用快捷键)

0.下载 pycharm官网下载 选择合适的版本&#xff0c;本文以2024.1为例 1.简单应用 常用快捷键 ctrlD 复制当前行 ctrlY 删除当前行 ctrlX 剪切当前行&#xff08;可用作删除&#xff0c;更顺手&#xff09; shift↑ 选中多行ctrlshiftF10 运行 shiftF9 调试ctrl/ 注释当前…

数据结构入门:探索数据结构第一步

0.引言 在我们的日常生活中&#xff0c;经常需要管理大量的数据&#xff0c;就譬如学校中有好几千个学生&#xff0c;中国有十三亿人口&#xff0c;对于那么多的数据进行查找、插入、排序等操作就会比较慢。人们为了解决这些问题&#xff0c;提高对数据的管理效率&#xff0c;…

docker被封禁,怎么拉取镜像,打包所有镜像

因为docker被国内封禁了&#xff0c;所以我把电脑上之前的镜像全部打包出来了 你们也可以打包&#xff0c;我提供一个脚本&#xff0c;你运行即可 export_docker.sh #!/bin/bash# 导出目录 EXPORT_DIR"docker_images_backup" mkdir -p "$EXPORT_DIR"# 获…