(求助)请大神来帮忙修改一下,代码一直报错,小白上路

我就想简单做一个将文件夹的EXCEL文件,用WPS合并一个新的文件到A列

# 获取数据范围中实际有数据的部分
used_range = range.SpecialCells(win32com.client.constants.xlCellTypeConstants)

这段一直报错,请大神帮忙看看是啥原因 

报错原因

Traceback (most recent call last):
  File "C:\Users\Administrator\Desktop\demo2.py", line 40, in <module>
    used_range = range.SpecialCells(win32com.client.constants.xlCellTypeConstants)
                                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "C:\Users\Administrator\AppData\Local\Programs\Python\Python311\Lib\site-packages\win32com\client\__init__.py", line 232, in __getattr__
    raise AttributeError(a)
AttributeError: xlCellTypeConstants

以下是全部代码

import os
import win32com.client

# 定义要处理的文件夹路径
folder_path = "E:\\BaiduNetdiskDownload\\范文大全"

# 定义要创建的新文件路径
new_file_path = "E:\\BaiduNetdiskDownload\\合并结果.xlsx"

# 创建 WPS 表格应用对象
app = win32com.client.Dispatch("Ket.Application")

# 设置应用为可见
app.Visible = True

# 创建一个新的工作簿对象
new_workbook = app.Workbooks.Add()

# 获取新工作簿的第一个工作表对象
new_sheet = new_workbook.Worksheets(1)

# 定义一个变量,用于记录新工作表中已经写入的行数
row_count = 1

# 遍历文件夹中的所有文件
for file in os.listdir(folder_path):
# 获取文件的完整路径
file_path = os.path.join(folder_path, file)
# 获取文件的名称和扩展名
file_name, file_ext = os.path.splitext(file)
# 判断文件是否是 WPS 表格文件
if file_ext in [".xls", ".xlsx"]:
# 打开 WPS 表格文件
workbook = app.Workbooks.Open(file_path)
# 获取第一个工作表对象
sheet = workbook.Worksheets(1)
# 获取第一个工作表中 A 列的数据范围对象
range = sheet.Range("A:A")
# 获取数据范围中实际有数据的部分
used_range = range.SpecialCells(win32com.client.constants.xlCellTypeConstants)
# 复制数据范围到剪贴板
used_range.Copy()
# 获取新工作表中对应的目标单元格对象,根据已经写入的行数确定起始位置
target_cell = new_sheet.Cells(row_count, 1)
# 粘贴剪贴板中的数据到目标单元格,保留源格式
target_cell.PasteSpecial(win32com.client.constants.xlPasteAll)
# 更新已经写入的行数,加上本次粘贴的行数
row_count += used_range.Rows.Count
# 关闭 WPS 表格文件,不保存更改
workbook.Close(False)

# 保存新工作簿到指定路径
new_workbook.SaveAs(folder_path)

# 退出 WPS 表格应用
app.Quit()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值