当前位置:   article > 正文

Python操作excel进行插入、删除行操作实例演示,利用xlwings库实现_python插入excel行

python插入excel行

第一章:整行插入与删除

① Excel 的插入行实例演示

插入行演示采用正序遍历操作,直接使用 xlwings 提供的 sheet.api.Rows("行数").Insert() 方法就能实现整行插入处理。
需要注意的是,如果是前插入,要避免再次检测到刚才匹配过的内容,以防循环反复插入原位置。

# -*- coding:utf-8 -*-
# excel增行、删行实现

import xlwings

# 参数visible设置False不显示excel界面,默认是True显示的
app = xlwings.App(visible=False)
# 修改文件路径
path_xl = 'C:\\Users\\Administrator\\Desktop\\增、删行测试.xls'
# 加载excel文件
wt = app.books.open(path_xl)
# 加载第一个sheet页签
sheet = wt.sheets[0]

def xl_insert(m_col, m_text):
    '''
     作用:插入excel
     参数1:需要匹配的列
     参数2:需要匹配的内容
    ····
     创建:小蓝枣
     更改:2021-06-01
    '''
    global sheet;
    
    # 读取行数
    rows = sheet.used_range.last_cell.row

    # 如果从n行上面插入,需要想办法跳过n+1这一行,n+1正是插入后原来n行的脚本,不然会发生死循环
    k = 0   # 记录插入行
    for i in range(1, rows):
        
        # 检测到已插入的行进行跳过处理
        if(i == k):
            continue;
            
        if(sheet.range(m_col + str(i)).value == m_text):
            print("对第 " + str(i) + " 行进行了插入行操作!")
            sheet.api.Rows(i).Insert()
            k = i+1;

# 匹配C列,对相关内容进行插入
xl_insert('C', '//*[@fieldid="header-area"]//*[@fieldid="Add_btn"]')

# 不指定路径,脚本会直接保存到原文件
wt.save()
# 释放资源,不然脚本无法打开,会处于锁定状态。
wt.close()
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48

调整前:
在这里插入图片描述
处理过程:
在这里插入图片描述
调整后:
在这里插入图片描述

② Excel 的删除行实例演示

删除行演示采用逆序遍历操作,直接使用 xlwings 提供的 sheet.range("单元格").api.EntireRow.Delete() 方法就能实现整行删除处理。
此次使用逆序遍历,直接避免了行错位引起的各种问题。【推荐】

# -*- coding:utf-8 -*-
# excel增行、删行实现

import xlwings

# 参数visible设置False不显示excel界面,默认是True显示的
app = xlwings.App(visible=False)
# 修改文件路径
path_xl = 'C:\\Users\\Administrator\\Desktop\\增、删行测试.xls'
# 加载excel文件
wt = app.books.open(path_xl)
# 加载第一个sheet页签
sheet = wt.sheets[0]

def xl_delete(m_col, m_text):
    '''
     作用:excel删行
     参数1:需要匹配的列
     参数2:需要匹配的内容
    ····
     创建:小蓝枣
     更改:2021-06-01
    '''
    global sheet;
    
    # 读取行数
    rows = sheet.used_range.last_cell.row
    # 正序的话本行删除后,后面的行就有变化了,采用倒叙匹配解决了该问题
    for i in range(rows, 1, -1):
        if(sheet.range(m_col + str(i)).value == m_text):
            print("对第 " + str(i) + " 行进行了删除行操作!")
            sheet.range(m_col + str(i)).api.EntireRow.Delete()
            k = i+1;

# 匹配C列,对相关内容进行删行
xl_delete('D', 'gys_qj_sckh002')

# 不指定路径,脚本会直接保存到原文件
wt.save()
# 释放资源,不然脚本无法打开,会处于锁定状态。
wt.close()
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41

调整前:
在这里插入图片描述
处理过程:
在这里插入图片描述
调整后:
在这里插入图片描述
喜欢的点个赞❤吧!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/69575
推荐阅读
相关标签
  

闽ICP备14008679号