使用python套用excel模板_Python自动化办公Excel-从表中批量复制粘贴数据到新表

1、模块安装

1)cmd模式下:

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple xlrd

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple openpyxl

2)如果有安装Pycharm,则在程序中操作如下:

菜单栏:File -> Settings -> Project: **.py -> Project INterpreter -> + search xlrd

菜单栏:File -> Settings -> Project: **.py -> Project INterpreter -> + search openpyxl

2、思路步骤

步骤如下:

1.提取“原报表”第8行往下不为空的数据

2.写入到“抽出数据报表”数组中,设置写入内容的格式及边框、行高等,保存

资源下载:

watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80Mjc1MDYxMQ==,size_16,color_FFFFFF,t_70#pic_center

1)提取

使用xlrd。读取工作簿,存入wb,然后选取第一个工作表,存入ws。新建一个列表data用于储存获取的数据。然后从第8行(对应索引为0)遍历工作表。将每行的数据放入列表info_list。在写入到数组之前,用if语句设置两个条件:先判断是不是空值,再判断长度是否大于1000mm,才放入总列表data。

import xlrd

file = "汇总.xlsx"

wb = xlrd.open_workbook(file,on_demand=True) # 读取工作簿

ws = wb.sheets()[0] # 选第一个工作表

data = []

title1 = ws.cell(0,0).value.strip() #读取标题,非数字

# print(title1)

for row in range(2, ws.nrows):

col1= ws.cell(row, 0).value

col2 = ws.cell(row, 1).value

col3 = ws.cell(row, 2).value

info_list = [col1, col2, col3]

if info_list[0] != "": # 去除空数据

if col1 >1000:

data.append(info_list)

print(data)

data数据如下:

[[1594.0, 400.0, 38.0], [1045.0, 300.0, 38.0], [2480.0, 149.0, 20.0], [1174.0, 153.0, 20.0], [1450.0, 180.0, 45.0], [1100.0, 90.0, 90.0], [1123.0, 90.0, 90.0], [1155.0, 90.0, 90.0], [1050.0, 53.0, 53.0], [1100.0, 70.0, 45.0], [2050.0, 70.0, 45.0], [2340.0, 70.0, 45.0], [3590.0, 70.0, 45.0]]

2)写入

获取完数据,开始写入统计表。顺便导入“设置单元格格式”的相关的模块。因为数据列表data中全是子列表,所以直接使用append方法整行写入最为方便。数据写完后,需要设置行高,字号,加粗,对齐,单元格边框等。全部设置完后保存数据。

from openpyxl import load_workbook

from openpyxl.styles import Border, Side, PatternFill, Font, GradientFill, Alignment #设置单元格格式

thin = Side(border_style="thin", color="000000")#定义边框粗细及颜色

file = "统计表模板.xlsx"

wb = load_workbook(file)

ws = wb.active

#写入数据

for i in data:

ws.append(i)

#设置字号,对齐,缩小字体填充,加边框

#Font(bold=True)可加粗字体

for row_number in range(2, ws.max_row+1):

ws.row_dimensions[row_number].height = 25 #设置行高

for col_number in range(1,4):

c = ws.cell(row=row_number,column=col_number)

c.font = Font(size=11,bold=True)

c.border = Border(top=thin, left=thin, right=thin, bottom=thin)

c.alignment = Alignment(horizontal="center", vertical="center")

wb.save("统计表.xlsx")

完整代码如下:

import xlrd

file = "汇总.xlsx"

wb = xlrd.open_workbook(file,on_demand=True) # 读取工作簿

ws = wb.sheets()[0] # 选第一个工作表

data = []

title1 = ws.cell(0,0).value.strip() #读取标题,非数字

# print(title1)

for row in range(2, ws.nrows):

col1= ws.cell(row, 0).value

col2 = ws.cell(row, 1).value

col3 = ws.cell(row, 2).value

info_list = [col1, col2, col3]

if info_list[0] != "": # 去除空数据

if col1 >1000:

data.append(info_list)

print(data)

from openpyxl import load_workbook

from openpyxl.styles import Border, Side, PatternFill, Font, GradientFill, Alignment #设置单元格格式

thin = Side(border_style="thin", color="000000")#定义边框粗细及颜色

file = "统计表模板.xlsx"

wb = load_workbook(file)

ws = wb.active

#写入数据

for i in data:

ws.append(i)

#设置字号,对齐,缩小字体填充,加边框

#Font(bold=True)可加粗字体

for row_number in range(2, ws.max_row+1):

ws.row_dimensions[row_number].height = 25 #设置行高

for col_number in range(1,4):

c = ws.cell(row=row_number,column=col_number)

c.font = Font(size=11,bold=True)

c.border = Border(top=thin, left=thin, right=thin, bottom=thin)

c.alignment = Alignment(horizontal="center", vertical="center")

wb.save("统计表.xlsx")

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

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

相关文章

在HubSpot是如何应对Fat JAR困境的

在七月底,Spring Boot和Dropwizard分别发布了1.4和1.0版本,它们都是基于Fat JAR的。随着人们更多地采用这些框架和微服务架构,Fat JAR成为了通用的部署机制。\\Fat JAR技术会将Java应用的所有依赖打包到一个bundle之中,便于执行&a…

给定数字的b+树创建_在C ++中找到给定数字中的两个的下一个和上一个幂

给定数字的b树创建Problem statement: 问题陈述: Find Next and previous power of two of a given number 查找给定数字中两个的下一个和上一个幂 Next power of two 下一个二的幂 Example(1):input: 22output: 32 ( as 32 is 2^5)Example(2):input: 54output…

java 字节数组作用_这段java代码中字节数组b起到了什么作用?

importjava.io.*;importjavax.swing.*;publicclassIOMonitor{publicstaticvoidmain(String[]temp){//TODO自动生成的方法存根byteb[]newbyte[2];try{FileInputStreamfisnewFileInput...import java.io.*;import javax.swing.*;public class IOMonitor {public static void main…

如何查看本地的崩溃log_过年回家,还怕抢不到票?程序员教你如何抢票

2019年接近尾声,距离春节回家的日子越来越近,26日起,2020年除夕火车票正式开售,抢票大战也进入白热化阶段。是否为某抢票 App 加速而烦恼,是否为车票“秒光而烦恼”。别慌,作为连“对象”都是 new 出来的程…

获取列表中包含的元素数 在C#中

Given a list, and we have to count its total number of elements using List.Count property. 给定一个列表,我们必须使用List.Count属性计算其元素总数 。 C#清单 (C# List) A list is used to represent the list of the objects, it is represent…

I00037 亏数(Deficient number)

数论中,若一个正整数除了本身之外所有因子之和比此数自身小,则称此数为亏数。亏数(Deficient number)也称为缺数,参见百度百科_亏数,或参见维基百科的Deficient number。亏数在OEIS中的数列号为A005100。 问…

hashmap转红黑树的阈值为8_面试必考的 HashMap,这篇总结到位了

点击蓝色“JavaKeeper”关注我哟加个“星标”,一起成长,做牛逼闪闪的技术人1 概述HashMap是基于哈希表实现的,每一个元素是一个key-value对,其内部通过单链表解决冲突问题,容量不足(超过了阀值)时,同样会自动增长.HashMap是非线程安全的,只适用于单线程环…

linux用户组管理命令_Linux用户和组命令能力问题和解答

linux用户组管理命令This section contains Aptitude Questions and Answers on Linux User and Group Commands. 本节包含有关Linux用户和组命令的 Aptitude问答。 1) Which of the following commands is used to create a new user in the Linux operating system? create…

Failed to start firewalld.service: Unit firewalld.service is masked.

2019独角兽企业重金招聘Python工程师标准>>> FireWall in Centos 7 masked How to resolve the error message belowFailed to issue method call: Unit firewalld.service is masked. The main reason a service is masked is to prevent accidental starting or e…

mysql第二个索引_MySQL高级第二章——索引优化分析

一、SQL性能下降原因1.等待时间长?执行时间长?可能原因:查询语句写的不行索引失效(单值索引、复合索引)CREATE INDEX index_user_name ON user(name);(底层做了一个排序)CREATE INDEX index_user_nameEmail ON user(name,email);查询关联join…

递归反转链表改变原链表吗_在不使用递归的情况下找到链表的长度

递归反转链表改变原链表吗Solution: 解: Algorithm to find length 查找长度的算法 Input: 输入: A singly linked list whose address of the first node is stored in a pointer, say head. 一个单链表 ,其第一个节点的地址存储在指针(例…

西瓜仿站高手v1.08官方正式版

2019独角兽企业重金招聘Python工程师标准>>> 西瓜仿站高手是一款绿色好用的由追风网络出品的网站模板批量下载软件,西瓜仿站高手是一款仿站工具,仿站神器。软件功能强大,能够帮你轻松帮你下载任意网站、任意模板,并且速…

用hundred造句子_八个有趣的开学破冰游戏,线上线下都能用

知道大家最近都很忙,所以省略开篇,直接上正题——开学“破冰游戏”走起!一、你比划我来猜把词语展示在PPT上,猜词的同学背对PPT,其他同学可以看到词语并且用身体动作把词语表现出来,直到猜词的同学可以把词…

java 执行顺序_Java代码执行顺序

程序中代码执行的顺序非常重要,稍有不慎便会是程序运行出错,那么我将结合实例来分析代码中的执行。名词解释首先了解几个名词:非静态代码块直接由 { } 包起来的代码,称为非静态代码块静态代码块直接由 static { } 包起来的代码&am…

mysql 包含的那些文件

*.frm是描述了表的结构 *.MYD保存了表的数据记录 *.MYI则是表的索引 ibd是MySQL数据文件、索引文件,无法直接读取。 转载于:https://www.cnblogs.com/07byte/p/5823667.html

math 计算float_Java Math类静态float min(float f1,float f2)与示例

math 计算float数学类静态浮点数min(float f1,float f2) (Math Class static float min(float f1 , float f2) ) This method is available in java.lang package. 此方法在java.lang包中可用。 This method is used to return the minimum one of both the given a…

vector 不初始化时什么状态_Vue原理解析(三):初始化时created之前做了什么?...

让我们继续this._init()的初始化之旅,接下来又会执行这样的三个初始化方法:initInjections(vm) initState(vm) initProvide(vm)5. initInjections(vm): 主要作用是初始化inject,可以访问到对应的依赖。inject和provide这里需要简单的提一下&a…

switch 字符串 java_JDK7新特性switch支持字符串

在JDK7中,switch语句的判断条件增加了对字符串类型的支持。由于字符串的操作在编程中使用频繁,这个新特性的出现为Java编程带来了便利。接下来通过一个案例演示一下在switch语句中使用字符串进行匹配。public class Example {public static void main(String[] args) {String w…

cisco packet tracer路由器配置_【干货】思科交换机路由器怎么配置密码?

今天带大家看看如何在思科的交换机路由器当中配置安全特性,也就是密码的配置方式。在学习配置之前,我们先回顾一下密码相关知识。密码学是研究信息系统安全保密的科学。人类有记载的通信密码始于公元前400年,古希腊人是置换密码学的发明者。密…

perl 哈希数组的哈希_使用哈希检查两个数组是否相似

perl 哈希数组的哈希Prerequisite: Hashing data structure 先决条件: 哈希数据结构 Problem statement: 问题陈述: Check whether two arrays are similar or not using the hash table. The arrays are of the same size. 使用哈希表检查两个数组是否…