- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为了构建报告,我使用 Access 计算一些数据,然后使用 VBA 宏导出多个表,然后该宏启动 Excel 并从 Excel 中运行另一个宏来编译所有内容。
一切都已经相当快了,但是除了 Access VBA 之外还需要一个包含 VBA 代码的 Excel 工作表,这让我很困扰。此外,我最近向我的数据库添加了许多新功能,可以选择生成多个报告,并在 Access Forms 上提供大量自定义功能。
对我来说,在这两个文件之间导航变得有些复杂,因此我尝试将 Excel 代码放入 Access 中,这样我的同事(最终用户)只需保持 1 个文件的最新状态即可计算机,并且它也会使调试变得更容易。
报告按预期构建,但过程慢了 5 倍。我尝试测量每个步骤所花费的时间,比率保持不变(除了最后构建 PowerPoint 演示文稿的部分)。
所以我决定尝试这段无用的代码:
Sub test()
Dim t As Double 'Starting time
t = Round(Timer)
Dim b As Workbook
Dim s As Worksheet
Dim i As Integer, j As Integer 'Loop variables
'Create workbook
Set b = Workbooks.Add
'Get worksheet
Set s = b.Sheets(1)
'Double Loop
For i = 1 To 100
For j = 1 To 100
s.Cells(i, j) = "Hi!" 'Write some useless comment
Next
Next
b.Close False 'Close without saving
'Message
MsgBox (Round(Timer) - t) \ 60 & "'" & Format((Round(Timer) - t) Mod 60, "00") & "''"
End Sub
我没有故意设置任何 ScreenUpdating=False、EnableEvents=False 等。
从 Excel 运行代码时,需要 2 到 3 秒。
从 Access 运行代码时,需要 7 到 10 秒!
据我所知,Access 必须向另一个应用程序发送指令,这可能会减慢该过程。因此,我尝试要求 Excel 在 Excel 的另一个实例中运行我的脚本(因此我创建了一个对象“Excel.Application”,将我的工作簿放入其中,这正是 Access 在后台执行的操作),并且我获得了与我相同的性能从 Access 运行代码。
有什么办法可以加快速度吗?更改 VB 脚本与其创建的应用程序对象通信方式的指令可能?
预先感谢大家的支持。
编辑:根据 ASH 的要求,这是我在 Access 中运行的完整代码(我不会放置我的报告代码,因为它非常庞大,有很多子、函数、自定义类等)。评论是法语,但这里有一个摘要:
第一个脚本是创建或打开 Excel 的函数工作簿,进行了一些优化(Excel 不可见,无屏幕更新、不计算等)
第二个脚本是关闭 Excel 工作簿的子脚本,其中保存/另存为以及放弃优化的选项第一个函数
第三个脚本是我之前放置的测试代码的替代版本。
现在来看看代码本身:
Option Explicit
Function Ouvrir_Classeur_Excel(Optional Fichier As String, Optional Optimiser As Boolean = False) As Workbook
'*********************************** Descriptif
'Ouvre (ou crée) un classeur Excel en appliquant une optimisation si demandé par l'utilisateur.
'L'optimisation cache et désactive le rafraîchissement visuel d'Excel, les messages d'alerte, les événements et les calculs automatiques.
'------------------ Paramètres
'Fichier : Le chemin du classeur à ouvrir. S'il est vide, un classeur est créé
'Optimiser : Indique si les scripts d'optimisation doivent être exécutés. Par défaut, cette option est désactivée
'*********************************** Exécution
With Excel.Application
If Optimiser Then
'Excel invisible
.Visible = False
'Désactivation du rafraîchissement
.ScreenUpdating = False
'Désactivation des messages d'alerte
.DisplayAlerts = False
'Désactivation des événements
.EnableEvents = False
End If
'Ouverture/Création du classeur
If Fichier <> "" Then Set Ouvrir_Classeur_Excel = Workbooks.Open(Fichier) 'Si on a spécifié un fichier, il est ouvert
If Fichier = "" Then Set Ouvrir_Classeur_Excel = Workbooks.Add 'Si on n'a pas spécifié de fichier, on en crée un
'Désactivation des calculs automatiques
If Optimiser Then .Calculation = xlCalculationManual
End With
End Function
Sub Fermer_Classeur_Excel(Classeur As Workbook, Optional Enregistrer As Boolean = False, _
Optional Emplacement As String, Optional Fin_Optimisation As Boolean = False)
'*********************************** Descriptif
'Ferme le classeur Excel spécifié.
'Si l'utilisateur le demande, le classeur peut être enregistré, ou enregistré sous.
'Si l'utilisateur le demande, les optimisations appliquées par la fonction Ouvrir_Classeur_Excel peuvent être annulées.
'------------------ Paramètres
'Classeur : Le classeur à fermer
'Enregistrer : Indique si le classeur doit être enregistré. Par défaut, cette option est désactivée
'Emplacement : Indique l'emplacement où enregistrer le classeur. Si vide, l'enregistrement sera simple.
'Fin_Optimisation : Indique si les optimisations doivent être annulées. Par défaut, cette option est désactivée
'*********************************** Exécution
With Excel.Application
'Enregistrement du classeur
If Enregistrer Then
If Emplacement = "" Then Classeur.Save
If Emplacement <> "" Then Classeur.SaveAs Emplacement
End If
'Réactivation des calculs automatiques
If Fin_Optimisation Then .Calculation = xlCalculationAutomatic
'Fermeture du classeur
Classeur.Close False
If Fin_Optimisation Then
'Réactivation du rafraîchissement
.ScreenUpdating = True
'Réactivation des messages d'alerte
.DisplayAlerts = True
'Réactivation des événements
.EnableEvents = False
End If
End With
End Sub
Sub testA()
'------------Relève de l'heure de début
Dim tGlo As Double 'Heure de début d'exécution du script
Dim infoFin As String
tGlo = Round(Timer)
Dim x As Excel.Application
Dim c As Workbook
Dim f As Worksheet
Dim i As Integer, j As Integer
Set c = Ouvrir_Classeur_Excel(, True)
Set f = c.Sheets(1)
i = 1
Do Until i = 100
j = 1
Do Until j = 100
f.Cells(i, j) = "Coucou"
j = j + 1
Loop
i = i + 1
Loop
Fermer_Classeur_Excel c, , , True
'------------Message de fin
infoFin = infoFin & Chr(10) & Chr(10) & "DUREE DE TRAITEMENT : " & (Round(Timer) - tGlo) \ 60 & "'" & Format((Round(Timer) - tGlo) Mod 60, "00") & "''"
MsgBox infoFin, , title:="** FIN DU TRAITEMENT **"
End Sub
像这样,需要 2 到 7 秒(Excel 已经运行),与具有相同优化的 Excel 中不到 1 秒相比,这是巨大的。
问题是,它在这里似乎并不那么重要,但在 Excel 中通常需要 40 秒的另一个过程,当我将其迁移到 Access 时花了 3 分钟多。我还有另一个(尚未优化)在 Excel 中需要超过 3:30,我什至不敢尝试在 Access 中运行它。
最佳答案
我知道您提到您在 Access 中有很多自定义过程来生成各种报告,但是有什么原因您不能将该代码移至 Excel 吗?我已经构建了几个在 Excel 中运行代码但使用 Access 作为数据源的解决方案,并且它们非常快 - 您在 Access 中构建的用于自定义报告的用户表单必须在 Excel 中重新构建,但可以解决 Excel 之间的性能问题/Access ...
希望这有帮助,丝绸密码
关于excel - VBA - 加速 Access 发送的 Excel 指令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41383383/
我正在使用 voip 推送通知制作 ios 应用程序。 我想从 Node js 发送 voip 推送通知,但不是很好。 我阅读了本教程 CallKit iOS Swift Tutorial for V
我编写了一个服务器,当浏览器尝试连接到某些站点时,它会检查黑名单并发回 404,但是当我调用 send() 时没有错误,但消息不会出现在网络上浏览器,除非我关闭连接? 有什么建议吗? 接受来自浏览器的
#include int main() { char c = getchar(); //EOF (ctrl + d ) while( ( c = getchar() ) != '?'
我正在尝试使用MailMessage对象通过PowerShell发送电子邮件。该脚本使用Import-CSV来使用文件,然后在电子邮件正文中使用ConvertTo-HTML。由于我要发送的电子邮件客户
我需要创建一个脚本,每 30 秒对网络流量进行一次采样并存储发送/接收的字节。该数据随后用于绘制图形。我编写了一个在 Windows 2012 上完美运行的程序,但我意识到某些 cmdlet 在以前的
我正在运行“autoit3.chm”文件。当它运行时,我想发送一个向下键箭头,但它不起作用: $file = FileGetShortName("C:\Users\PHSD100-SIC\Deskto
当我使用网络浏览器测试我的程序时,我可以很好地写入套接字/FD,所以我决定循环它并在连接中途切断连接,我发现了一个问题。 send() 能够在套接字不可用时关闭整个程序。我认为问题在于该程序陷入了第
我正在运行“autoit3.chm”文件。当它运行时,我想发送一个向下键箭头,但它不起作用: $file = FileGetShortName("C:\Users\PHSD100-SIC\Deskto
所以我试图向自己发送数据并接收数据然后打印它,现在我已经测试了一段时间,我注意到它没有发送任何东西,事实上,也许它是,但我没有正确接收它,我需要这方面的帮助。 这就是我用来发送数据的
问题:开发人员创建自己的序列化格式有多常见?具体来说,我使用 java 本质上将对象作为一个巨大的字符串发送,并用标记来分隔变量。 我的逻辑:我选择这个是因为它几乎消除了语言依赖性(忽略java的修改
我必须在 Linux 上编写一个应用程序,该应用程序需要与具有自定义以太网类型的设备进行通信。甚至在如何编写这样的应用程序中也有很多解决方案。一个缺点是需要 root 访问权限(AFAIK)。之后释放
我有一个包含三个单选按钮选项的表单。我需要将表单数据提交到另一个文件,但由于某种原因,发送的数据包含所选单选按钮的值“on”,而不是 value 属性的值。 我尝试通过 post() 函数手动操作和发
基本上我想实现这样的目标: Process 1 Thread 1 Receive X from process 2 Thread 2 Receive Y from proces
我目前正在 Google App Engine 上开发一个系统,对它还很陌生,我正在使用 Java 平台进行开发。我在 servlet 之间发送 session 对象时遇到问题。我已经在 appeng
当我尝试将“this”(触发的元素)作为参数发送给函数时,函数收到“Object[Document build.php]”作为参数,而不是触发的元素。请让我知道我的错误: function set(a
我正在寻找让我的应用响应联系人 > 发送的魔法咒语。我希望能够接收联系人的 URI 以便检索联系人。谁有 list 过滤器/代码 fragment 吗? 最佳答案 我没有睾丸,但您可以尝试基于 ACT
关于我心爱的套接字的另一个问题。我先解释一下我的情况。之后我会告诉你是什么困扰着我。 我有一个客户端和一个服务器。这两个应用程序都是用 C++ 编写的,实现了 winsock2。连接通过 TCP 和
我看到了这篇文章 http://www.eskimo.com/~scs/cclass/int/sx5.html 但这部分让我感到困惑:如果我们已经使用 send_array 或 send_array_
我对这行代码有疑问。我必须将一个数据包带到一个端口并重新发送到接口(interface)(例如:eth0)。我的程序成功地从端口获取数据包,但是当我重新发送(使用 send())到接口(interfa
我正在尝试编写一个 X11 输入驱动程序,它可以使用我的 Android 手机上的触摸屏来移动和单击鼠标。我可以正常移动鼠标,但我无法让应用程序正确识别点击。我当前的代码位于 https://gist
我是一名优秀的程序员,十分优秀!