品易云推流 关闭
文章详情页
文章 > Python基础教程 > Python中使用xlwings整行删除

Python中使用xlwings整行删除

头像

小妮浅浅

2021-06-02 15:57:56944浏览 · 0收藏 · 0评论

1、方法说明

删除行演示采用逆序遍历操作,直接使用xlwings提供的sheet.range("单元格").api.EntireRow.Delete() 方法就能实现整行删除处理。

使用逆序遍历,直接避免了行错位引起的各种问题。

2、实例

# -*- 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:需要匹配的内容
    '''
    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()

以上就是Python中使用xlwings整行删除的方法,希望对大家有所帮助。更多Python学习指路:python基础教程

关注

关注公众号,随时随地在线学习

本教程部分素材来源于网络,版权问题联系站长!

底部广告图