EXCEL 自动保存为PDF

from win32com import client
def to_pdf(filename,folder):

    df=pd.read_excel(target_path,sheet_name='总目录')

    Rukudan = sorted(list(set(list(df['编号']))))

    filelist=os.listdir(folder)

    for i in Rukudan:

        i=i+'.pdf'
        #保存过PDF的就不保存了,这点需要注意, 如果想重新保存需要先删掉对应的PDF
        if i not in filelist:
            exportfile = os.path.join(folder, i)

        # Open Microsoft Excel
            excel = client.Dispatch("Excel.Application")

        # Read Excel File
            sheets = excel.Workbooks.Open(filename)
            work_sheets = sheets.Worksheets[i[-10:-4]]

        # Convert into PDF File
            work_sheets.ExportAsFixedFormat(0, exportfile)

            print('保存 PDF 文件:', exportfile)
        # close Excel File
            sheets.Close(False)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
VBA是Visual Basic for Applications的缩写,用于微软Office项目的编程语言。VBA开发人员可以编写VBA代码来自动完成复杂任务,可以大大提高工作效率。在日常工作中,我们常常需要将Excel文件转换为PDF格式,以便在不同平台上共享和传递。手动将每个Excel文件转换为PDF格式是非常繁琐的,因此使用VBA将Excel文件批量转换为PDF格式是非常有用的。 使用VBA批量转换Excel文件为PDF的主要步骤如下: 1.打开需要转换的Excel文件所在的目录。 2.遍历目录中的每个Excel文件,使用VBA代码将其转换为PDF格式。 3.保存转换后的PDF文件。 在这个过程中,需要使用VBA的文件操作和打印功能。文件操作需要使用FileSystemObject或Dir函数。打印功能可以使用PrintOut方法或PdfCreator等第三方库。 以下是一个简单的VBA代码示例,演示如何批量Excel文件转换为PDF。代码中假设所有的Excel文件都保存在同一个文件夹中。 Sub ConvertToPDF() Dim myPath As String Dim myFile As String Dim Wb As Workbook '指定文件夹的路径 myPath = "C:\Users\MyFolder\" '获取文件夹中的第一个文件名 myFile = Dir(myPath & "*.xlsx") '遍历所有文件 Do While myFile <> "" '打开工作簿 Set Wb = Workbooks.Open(myPath & myFile) '将工作簿另存为PDF文件 Wb.ExportAsFixedFormat Type:=xlTypePDF, Filename:= _ myPath & Replace(myFile, ".xlsx", ".pdf"), Quality:=xlQualityStandard, _ IncludeDocProperties:=True, IgnorePrintAreas:=False, OpenAfterPublish:=False '关闭工作簿 Wb.Close SaveChanges:=False '获取文件夹中的下一个文件名 myFile = Dir Loop End Sub 这个VBA代码示例非常简单,只是将Excel文件转换为PDF格式并保存在同一个文件夹中。但是,根据具体需求,可以进一步优化代码以满足不同的转换需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值