【问题标题】:Fastest (and safest) way to create 1300 workbooks?创建 1300 个工作簿的最快(和最安全)方法?
【发布时间】:2023-03-15 01:07:01
【问题描述】:

我有一个包含一些数据的工作簿,我想对其进行过滤,然后将过滤后的数据保存到新工作簿中。函数如下所示:

Sub bleh()
  For Each i In Number
       ~~ filter, copy, paste, save ~~
  Next i 
End Sub

除了优化代码,是不是更快更安全

  1. 在每次迭代中将每个工作表保存为新工作簿
  2. 保存当前工作簿中的每个工作表并剪切整个工作簿 最后放入单独的工作簿中?

或者别的什么?

感谢您的意见。

【问题讨论】:

  • 出于安全考虑,我不会在保存之前创建 1300 个工作表。另外,我会将各个操作集中到一个单独的子程序中,以便可以对变量进行垃圾收集。例如。 Sub Loop() For i = 1 to 1300 Call DoSave(workbook i) Next i End Sub.
  • quote: ...最后将整个工作簿剪切成单独的工作簿... 这与 ...将每个工作表保存为新工作簿相同... 只是没有保存...只是按逻辑,你已经回答了你自己的问题;)
  • 但是要比使用工作表和拆分以及其他任何操作更快:将值推送到变量中 -> 将结果计算为一个长字符串 -> 写入文本文件(另存为 csv);)跨度>
  • @DirkReichel 我明确强调了两个因素 - 速度和安全性。
  • 也许如果数据是集中的,您可以创建一个模板(您将复制它 1300 次,然后重命名每个模板),它只使用 SQL 来选择所需的数据。您可以使用特定名称命名每个工作簿,这将转换为 SQL 语句的选择标准。

标签: vba excel


【解决方案1】:

1,300 个文件?忘记 VBA,甚至忘记 Excel 互操作。

我会使用一些 C# 或 VB.NET,并使用 OpenXML 来处理文件的结构,在内存中异步生成 1,300 个 OpenXML 文档(即工作簿)(希望不会有数百个)每张表有数千行数据),然后一旦你掌握了所有你需要知道的东西,迭代所有这些工作簿对象并将它们按顺序保存到磁盘(可能显示一个进度条或其他东西)。无论如何,使 I/O 异步不会有任何帮助。

每个文件写入都将包装在一个try/catch 块中,并且该过程中引发的任何异常都将通过记录足够的信息来处理,以便稍后识别失败的工作表(可以输出到该进度条下的锁定文本框),并且然后继续尝试下一个。


在 VBA 中执行此操作将永远运行:给每个工作簿 4 秒的时间来创建、保存和关闭 - 您的宏将运行至少 5,200 秒,这几乎是一个半小时。

【讨论】:

  • 我的时间仅限于手动完成工作。从 VBA 到 VB.NET 远吗?
猜你喜欢
  • 2012-02-21
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2010-10-19
  • 2023-03-07
  • 1970-01-01
  • 1970-01-01
  • 2014-07-25
相关资源
最近更新 更多