0

我正在寻找执行以下操作的最佳解决方案:

我有大约 640 个 Excel 文件,每个文件大约有 9 - 12 张。我想将每张纸保存为 PDF。目前,该过程是手动完成的。选择工作表 -> 文件 -> 另存为 -> pdf -> 浏览一百万个文件夹。如您所见,这非常耗时且效率低下。

我知道如何用 C# 编程,但是我的机器上没有 Visual Studio。但是,如果最好的方法是 VS,那么如果 IT 团队有我的许可证,我可以让他们安装 VS。

我唯一可用的工具是 Excel(甚至 Access 都不可用)。所以我将主要寻找VBA代码。如果这意味着打开每个文件以粘贴 VBA 代码,那么将每个工作表保存为 PDF 仍然会更快。

4

1 回答 1

2

您可以使用 PowerShell 实现您的目标

ExportTo-ExcelPDF.ps1

$path = "c:\fso" 
$xlFixedFormat = "Microsoft.Office.Interop.Excel.xlFixedFormatType" -as [type] 
$excelFiles = Get-ChildItem -Path $path -include *.xls, *.xlsx -recurse 
$objExcel = New-Object -ComObject excel.application 
$objExcel.visible = $false 
foreach($wb in $excelFiles) 
{ 
 $filepath = Join-Path -Path $path -ChildPath ($wb.BaseName + ".pdf") 
 $workbook = $objExcel.workbooks.open($wb.fullname, 3) 
 $workbook.Saved = $true 
"saving $filepath" 
 $workbook.ExportAsFixedFormat($xlFixedFormat::xlTypePDF, $filepath) 
 $objExcel.Workbooks.close() 
} 
$objExcel.Quit()

http://blogs.technet.com/b/heyscriptingguy/archive/2010/09/06/save-a-microsoft-excel-workbook-as-a-pdf-file-by-using-powershell.aspx

在 C# 中使用相同的 COM API 也相当简单,您可以使用免费的 Visual Studio 2012 Express 来完成。

于 2013-07-08T18:49:27.903 回答