如何用python复制粘贴excel指定单元格(可保留格式)

 更新时间:2023年07月14日 09:02:44   作者:乡村大师i  
这篇文章主要给大家介绍了关于如何用python复制粘贴excel指定单元格(可保留格式)的相关资料,利用python操作excel非常方便,文中通过实例代码介绍的非常详细,需要的朋友可以参考下

近期学习了openpyxl的用法,发现居然没有【复制、粘贴】这么基础的函数。而且若要用python带格式复制粘贴指定区域的单元格,参考资料更少。

于是参考各路大佬的笔记,整合如下。

本代码只完成一次复制粘贴,各位可根据自己的需要加以利用,比如:可搭配遍历文件等实现多个excel中指定区域的复制,并汇总于指定区域的内容。

# 复制区域cell、带格式粘贴: 比如把a1:f16带格式复制粘贴到h23:m38
 
#导入包
import openpyxl
import copy
 
#path单引号内放入指定要操作的excel的路径 (本文举例的复制与粘贴,位于同一excel的同一sheet)
path = r'E:\OneDrive\Python_Note\Excel操作\03\反馈表-小寨支行.xlsx' 
wb = openpyxl.load_workbook(path)
ws = wb.active  #本行代码意思是指定ws为当前在excel中处于选中状态的sheet为ws。
                #若excel内有多个sheet,建议使用ws=wb['sheet的名字']
 
#以字符串输入复制、粘贴的区域,如'a1:f16','h23:m38'(必须大小一致)
Source_Area = 'a1:f16'  
Target_Area = 'h23:m38'
 
#分别指定复制和粘贴所在sheet的位置(本文复制粘贴的单元格区域都在ws内,ws是什么在上面已经指定好)
source_area = ws[Source_Area]   
target_area = ws[Target_Area]  
 
#创造source_cell_list,用以和target_cell_list一一对应:
source_cell_list = []
for source_row in source_area:
    for source_cell in source_row:
        sc_str = str(source_cell)  
        point_time = sc_str.count('.')
        sc_str = sc_str.replace('.', '', point_time - 1)
        start = sc_str.find('.')
        sc_str = sc_str[start+1 : -1]
        source_cell_list.append(sc_str) #提取出单元格编号的字符串,如'C8'
print('source_cell_list:',source_cell_list)
target_cell_list = []
for target_row in target_area:
    for target_cell in target_row:
        tc_str = str(target_cell)  
        point_time = tc_str.count('.')
        tc_str = tc_str.replace('.', '', point_time - 1)
        start = tc_str.find('.')
        tc_str = tc_str[start + 1: -1]
        target_cell_list.append(tc_str)  # 提取出单元格编号的字符串,如'L10'
print('target_cell_list:',target_cell_list)
 
#获取要复制的单元格总个数:
cells = len(source_cell_list) 
 
#提取并复制格式:
i=0
while i<=cells-1:
    ws[target_cell_list[0+i]].data_type = ws[source_cell_list[0+i]].data_type
    if ws[source_cell_list[0+i]].has_style:
        ws[target_cell_list[0+i]]._style = copy.copy(ws[source_cell_list[0+i]]._style)
        ws[target_cell_list[0+i]].font = copy.copy(ws[source_cell_list[0+i]].font)
        ws[target_cell_list[0+i]].border = copy.copy(ws[source_cell_list[0+i]].border)
        ws[target_cell_list[0+i]].fill = copy.copy(ws[source_cell_list[0+i]].fill)
        ws[target_cell_list[0+i]].number_format = copy.copy(ws[source_cell_list[0+i]].number_format)
        ws[target_cell_list[0+i]].protection = copy.copy(ws[source_cell_list[0+i]].protection)
        ws[target_cell_list[0+i]].alignment = copy.copy(ws[source_cell_list[0+i]].alignment)
    # 通过引用方法粘贴值: ws['']=ws[''].value
    ws[target_cell_list[0+i]] = ws[source_cell_list[0+i]].value
    i+=1
 
#保存更改:(若复制粘贴来源于不同文件要分别保存)
wb.save(r'E:\OneDrive\Python_Note\Excel操作\03\反馈表-小寨支行-py改.xlsx')

再补充一下如何遍历到某个文件夹下所有的excel。这样就可以实现批量自动提取每个excel的指定位置的数据了:

#插入库(同样库只用插入一遍)
import openpyxl
import os
 
#指定文件夹路径:
path = r'E:\OneDrive\Python_Note\Excel操作'
 
#使用for循环对文件夹内的每个excel进行相同操作:
 
for file_name in os.listdir(path):
    if file_name.endswith('.xlsx') or file_name.endswith(".xls"):
        #本次循环对象excel文件的绝对路径:
        excel = path + '\\' + file_name 
        print('开始执行:',excel)
        wb = openpyxl.load_workbook(excel)
 
        #以下开始是在每个excel内的所需操作(根据自己需要)
        
        ws = wb.active #指定sheet名,推荐操作的excel都只有一个sheet时用,可以解决各excel里sheet名称不同的问题。
 
        Source_Area = 'a1:f16'  
        Target_Area = 'h23:m38'     
        source_area = ws[Source_Area]   
        target_area = ws[Target_Area] 

总结

到此这篇关于如何用python复制粘贴excel指定单元格的文章就介绍到这了,更多相关python复制粘贴excel指定单元格内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 利用python进行矩阵运算实例代码

    利用python进行矩阵运算实例代码

    这篇文章主要给大家介绍了关于如何利用python进行矩阵运算的相关资料,Numpy是Python编程语言中的一个核心库,专门用于处理多维数据和矩阵运算,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-12-12
  • Python使用turtle绘制有趣的龙年祝福动画

    Python使用turtle绘制有趣的龙年祝福动画

    这篇文章主要介绍了Python的内置库——小海龟(turtle),它是一个非常实用的绘画工具,不仅可以帮助我们绘制图形,还能让我们查看整个绘画过程,下面我们就来看看如何使用turtle绘制有趣的龙年祝福动画吧
    2024-01-01
  • conda管理Python虚拟环境的实现

    conda管理Python虚拟环境的实现

    本文主要介绍了conda管理Python虚拟环境的实现,主要包括使用conda工具创建、查看和删除Python虚拟环境,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • Django REST framework 分页的实现代码

    Django REST framework 分页的实现代码

    这篇文章主要介绍了Django REST framework 分页的实现代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-06-06
  • 分享Pandas库中的一些宝藏函数transform()

    分享Pandas库中的一些宝藏函数transform()

    Pandas具有很多强大的功能,transform就是其中之一,利用它可以高效地汇总数据且不改变数据行数,transform是一种什么数据操作?如果熟悉SQL的窗口函数,就非常容易理解了
    2021-09-09
  • 浅析Python中global和nonlocal关键字的妙用

    浅析Python中global和nonlocal关键字的妙用

    这篇文章主要来和大家一起深入探讨Python中关键词global和nonlocal的用法,包括详细的示例代码和实际应用场景,感兴趣的可以了解下
    2024-04-04
  • Python实现的在特定目录下导入模块功能分析

    Python实现的在特定目录下导入模块功能分析

    这篇文章主要介绍了Python实现的在特定目录下导入模块功能,结合实例形式分析了Python基于系统函数及import语句实现模块导入的相关操作技巧,需要的朋友可以参考下
    2019-02-02
  • 一文教你利用Python制作一个生日提醒

    一文教你利用Python制作一个生日提醒

    在国内,大部分人都是过农历生日,然后借助日历工具获取农历日期对应的阳历日期,以这一天来过生!这里还有一个痛点,即:每一年的农历生日对应的阳历日期都不一样,本篇文章将教你利用 Python 制作一个简单的生日提醒,需要的可以参考一下
    2022-12-12
  • libreoffice python 操作word及excel文档的方法

    libreoffice python 操作word及excel文档的方法

    这篇文章主要介绍了libreoffice python 操作word及excel文档的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • python 按不同维度求和,最值,均值的实例

    python 按不同维度求和,最值,均值的实例

    今天小编就为大家分享一篇python 按不同维度求和,最值,均值的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-06-06

最新评论