自动化办公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')

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

51.Python-web框架-Django开始第一个应用的增删改查

目录 1.概述 2.创建应用 创建app01 在settings.py里引用app01 3.定义模型 在app01\models.py里创建模型 数据库迁移 4.创建视图 引用头 部门列表视图 部门添加视图 部门编辑视图 部门删除视图 5.创建Template 在app01下创建目录templates 部门列表模板depart.ht…

网络编程(一)基本概念、TCP协议

文章目录 一、概念(一)网络发展阶段1. ARPAnet阶段2. TCP/IP两个协议阶段3. 网络体系结构和OSI开放系统互联模型4. TCP/IP协议簇体系结构(1) 应用层:(2)传输层:(3&#x…

电商平台“质价比”增量密码,藏在美妆价格战里

文|新熔财经 作者|宏一 电商平台越来越难赚到用户的钱了。 数据显示,今年4月,抖音护肤与彩妆总GMV达141.72亿元,同比增长32.66%,环比下滑8.87%。 即便是最受关注的美妆类淘宝主播李佳琦,今年…

【网络编程】基于TCP的服务器端/客户端

TCP是Transmission Control Protocol(传输控制协议)简写。因为TCP套接字是面向连接的,因此又称为基于流的套接字。 把协议分为多个层次,设计更容易,通过标准化操作设计开放式系统 网络层介绍 链路层 链路层是物理连接领域标准化的结果&…

推荐系统三十六式学习笔记:原理篇.近邻推荐09|协同过滤中的相似度计算方法有哪些?

目录 相似度的本质相似度的计算方法:1、欧式距离2、余弦相似度3、皮尔逊相关度4 、杰卡德(Jaccard)相似度 总结 相似度的本质 推荐系统中,推荐算法分为两个门派,一个是机器学习派,一个是相似度门派。机器学…

网络编程2----UDP简单客户端服务器的实现

首先我们要知道传输层提供的协议主要有两种,TCP协议和UDP协议,先来介绍一下它们的区别: 1、TCP是面向连接的,UDP是无连接的。 连接的本质是双方分别保存了对方的关键信息,而面向连接并不意味着数据一定能正常传输到对…

天熠电脑怎么更换文件夹位置?三种方法,轻松驾驭

在日常使用电脑的过程中,文件夹的管理和整理对于提升工作效率和保持桌面整洁至关重要。然而,随着文件的不断增多和项目的频繁切换,我们可能需要不断调整文件夹的位置以适应新的工作需求。今天,我们就以天熠电脑为例,为…

LeetCode | 20.有效的括号

这道题就是栈这种数据结构的应用,当我们遇到左括号的时候,比如{,(,[,就压栈,当遇到右括号的时候,比如},),],就把栈顶元素弹出,如果不匹配,则返回False,当遍历完所有元素后…

“圆周素数”算法题解析

什么是圆周素数? 将一个素数逐位轮转后,所得到的数依然是素数,那么就称这个数为圆周素数。 例如:197是一个素数,将它逐位轮转后所得到的数,971,719 依然是素数。 小于100的圆周素数一共有13个…

HLS入门实验

文章目录 一、HLS介绍1.1 什么是HLS1.2HLS与VHDL/Verilog编程技术有什么关系?1.3HLS的关键技术和技术局限性1.3.1关键技术1.3.2 技术局限性 二、HLS入门实验2.1安装Vivado2.2创建项目2.3添加文件2.4仿真2.5创建Vivado工程2.6生成IP核2.7添加代码 参考 一、HLS介绍 1.1 什么是…

MySQL的发展历程:欧洲诞生,中国兴盛,美国低谷

目录 1 早期历史 2 成长与发展 3 重大变化和收购 4 现代发展 5 结语 一直比较写一些数据库相关的技术和操作、优化等文章。但写数据库在中国一般也逃脱不了MySQL这个数据库。下面简单谈一些个人看法。 MySQL整体上是起于欧洲: 一直有开源社区运营&#xff0c…

社会组织上前台、高质量发展勇担当|番禺区社联会成立十周年大会

6月5日,番禺区社联会举行“社会组织上前台,高质量发展勇担当”庆祝成立十周年大会暨“百社联百村—助力百千万工程”专项行动启动仪式。 广东省社会组织总会副秘书长王洁珊,广州市民政局一级调研员李又文,番禺区委副书记、区长叶珊…

网络安全到底是什么?一篇概念详解(附学习资料)

一、什么是网络安全?(文末有资料) “网络安全是指网络系统的硬件、软件及其系统中的数据受到保护,不因偶然的或者恶意的原因而遭受到破坏、更改、泄露、系统连续可靠正常地运行,网络服务不中断。” 说白了网络安全就…

集合java

1.集合 ArrayList 集合和数组的优势对比: 长度可变 添加数据的时候不需要考虑索引,默认将数据添加到末尾 package com.itheima;import java.util.ArrayList;/*public boolean add(要添加的元素) | 将指定的元素追加到此集合的末尾 | | p…

DOM-获取元素

获取元素的方法&#xff1a; 方法一&#xff1a;根据id获取元素document.getElementById <div id"time">2024-6-4</div> 在script标签中&#xff1a;注意getElementById括号里面必须要有引号&#xff0c;获得的是对象类型 var timer document.getEle…

harmony相关开发参考文档

以下列举一些Harmony Os应用开发文档以及相关参考开源案例&#xff0c;可协助高效率开发&#xff1a; 1.鸿蒙NEXT开发官方资料&#xff1a;包含鸿蒙NEXT开发所有的特性&#xff0c;HarmonyOS SDK等&#xff0c;可以按需查阅&#xff0c;需要开通白名单&#xff1a;应用开发导读…

2024版CorelDRAW中文破解授权码激活码!立即下载CorelDRAW中文版终身永久破解下载攻略

在设计领域&#xff0c;CorelDRAW一直以其强大的图形编辑和矢量绘图功能而受到专业用户的青睐。随着CorelDRAW 2024的发布&#xff0c;设计师们迎来了更加丰富的工具和更新的功能&#xff0c;使得创意实现更为轻松和精准。对于追求成本效益的用户而言&#xff0c;CorelDRAW 202…

【SpringBoot + Vue 尚庭公寓实战】房间支付方式管理接口实现(三)

【SpringBoot Vue 尚庭公寓实战】房间支付方式管理接口实现&#xff08;三&#xff09; 文章目录 【SpringBoot Vue 尚庭公寓实战】房间支付方式管理接口实现&#xff08;三&#xff09;1、查询全部支付方式列表2、保存或更新支付方式3、根据ID删除支付方式 房间支付方式管理…

express入门03增删改查

目录 1 搭建服务器2 静态文件托管3 引入bootstrap4 引入jquery5 编写后端接口5.1 添加列表查询方法5.2 添加路由5.3 添加数据表格 总结 我们前两篇介绍了如何利用express搭建服务器&#xff0c;如何实现静态资源托管。那利用这两篇的知识点&#xff0c;我们就可以实现一个小功能…

如何手动实现multiSetIfAbsent、multiExpire

👽System.out.println(“👋🏼嗨,大家好,我是代码不会敲的小符,目前工作于上海某电商服务公司…”); 📚System.out.println(“🎈如果文章中有错误的地方,恳请大家指正!共同进步,共同成长✊”); 🌟System.out.println(“💡如果文章对您有所帮助,希望您可以三…