首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >在Excel中使用VSTO更新绑定数据表的速度很慢

在Excel中使用VSTO更新绑定数据表的速度很慢
EN

Stack Overflow用户
提问于 2017-11-22 22:56:48
回答 1查看 167关注 0票数 1

我有一个Excel VSTO应用程序,它在内存中存储一个大型数据表,并将其中的一部分绑定到工作表。用户可以更改他们选择显示的字段,并定期进行批量更新。

大量更新循环通过更新两个字段的datatable。此更新过程似乎非常慢(即。更新40多条记录可能需要20秒)。

datatable非常大(10,000行x 450列),既绑定到一个隐藏的工作表,也绑定到一个绑定到可见工作表的较小的视图(20个字段)。

对datatable的所有更新都是用代码完成的。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ProductRow = dt.Rows.Find(foundRows(i)("Primary Key"))
If IsNothing(ProductRow) = False Then
          ProductRow("DECISION") = "Some Value"
          Updated += 1
End If

我怀疑正是绑定到工作表的大量数据减慢了这一过程,但是任何加快这一过程的建议都是最受欢迎的。

EN

回答 1

Stack Overflow用户

发布于 2017-11-26 02:41:23

使用VSTO遍历电子表格几乎在任何有这么多行/列的事件中都会很慢。即使是VBA也不会那么擅长这项任务。

我建议你实现一个穷人的状态模型。换句话说,添加一列(必要时隐藏)来指示每一行的状态--特别是它是否已更改。进行任何更改时,请确保行状态的列已更新,以显示该行已被更改。如果您还没有完成此操作的方法,则可以通过worksheet change事件来完成此操作。

然后,当您在电子表格中循环时,只关注状态已更改的值。我的猜测是,您正在检查和更新每一行,即使是那些不需要更新的行。

作为最后的想法,这必须在Excel中完成吗?标准.NET网格中的数据绑定将几乎开箱即用地处理此问题。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47445120

复制
相关文章
C# Monitor:锁定资源
C#中, 通过System.Threading.Monitor类可以实现多线程中对某些代码块的同步访问,以确保数据的安全性。
zls365
2020/08/19
9020
C# Monitor:锁定资源
如果Service有多个实现类,它怎么知道该注入哪个ServiceImpl类?
方法一:Controller中注入service的时候使用@Autowired自动注入,@Qualifier("beanId")来指定注入哪一个。
Java旅途
2021/06/08
2.4K0
聊聊RAII
RAII(Resource Acquisition Is Initialization),全称资源获取即初始化,1984-1989年期间,比雅尼·斯特劳斯特鲁普和安德鲁·柯尼希在设计C++异常时,为解决资源管理时的异常安全性而使用了该用法,后来比雅尼·斯特劳斯特鲁普将其称为RAII
雪月清
2023/10/25
1990
聊聊RAII
C#类
C#是面向对象的语言,它使用类来进行抽象。在C#里,把类之中的变量统称为“数据成员”;类的函数称为“方法”。它的类基本和C++的是相似的。下面是一个非常简单的类。
zy010101
2019/05/25
7820
C++核心准则R.1: 使用资源句柄自动管理资源并RAII(资源获取即初始化)
To avoid leaks and the complexity of manual resource management. C++'s language-enforced constructor/destructor symmetry mirrors the symmetry inherent in resource acquire/release function pairs such as fopen/fclose, lock/unlock, and new/delete. Whenever you deal with a resource that needs paired acquire/release function calls, encapsulate that resource in an object that enforces pairing for you -- acquire the resource in its constructor, and release it in its destructor.
面向对象思考
2020/03/25
7700
RAII_ras raf
大家好,又见面了,我是你们的朋友全栈君。 http://baike.baidu.com/link?url=DUGlzCMqyZ2aInTkdpGWqW0f53fL-LWLu9nD3rGoJClIU
全栈程序员站长
2022/11/01
4040
C#工具类:DotNet C# 工具类库项目
说起来,我是一个DotNet的初学者,刚刚上手,到处找比较适合我这种刚入门水平的开源项目。在Gitee上我无意中碰到了一个值得向各位初学者推荐的入门项目。
开源指北
2022/12/26
1.2K0
C#工具类:DotNet C# 工具类库项目
C#——Directory类
Directory 文件夹 目录 创建文件夹 Directory.CreateDirectory(@"C:\Users\H0772690\Desktop\a"); 删除文件夹 Directory.Delete(@"C:\Users\H0772690\Desktop\a"); 剪切到指定地址 Directory.Move(@"C:\Users\H0772690\Desktop\a", @"C:\Users\H0772690\Documents\1
用户9857551
2022/06/28
5990
c#类(class)
类的定义是以关键字class开始的,后面跟类的名称,类的主题包含一个花括号里,下面是类定义的一般格式。
酱紫安
2020/07/21
6800
C# FileStream类
FileShare 枚举类型主要用于设置多个对象同时访问同一个文件时的访问控制,具体的枚举值如下。
全栈程序员站长
2022/09/15
7190
C#委托 如果委托发生异常事件
假如在写游戏,有一个人物,他会升级,那么在他升级的时候,需要给他添加潜力值,而判断升级是经验类需要写的。
林德熙
2018/09/18
1.4K0
dotnet Blazor 用 C# 控制界面行为
微软很久就在做 Blazor 但是我现在才开始创建一个测试项目,我想用 C# 去控制 HTML 界面。小伙伴也许会问现在前端不是烂大街么,为什么还需要 Blazor 来做。可能原因只有一个,就是可以使用 C# 写脚本,代码比较清真
林德熙
2022/08/04
7620
dotnet Blazor 用 C# 控制界面行为
如果串口驱动有问题,怎么调
a. 编译: arm-linux-gcc -o serial_test serail_test.c -static b. 在开发板上运行: ./serial_test </dev/XXX> // /dev/XXX为串口的设备节点
韦东山
2020/09/30
1.5K0
C++核心准则E.25:如果不能抛出异常,模仿RAII方式进行资源管理
Even without exceptions, RAII is usually the best and most systematic way of dealing with resources.
面向对象思考
2020/08/10
6040
内存管理之堆、栈、RAII
最近在极客时间上看到吴老师的《现代C++实战30讲》,觉得很是不错,于是学习一下,本文中的一些文字概念引用自这里。同时,对于这个课的代码我放在了我的《C++那些事》仓库里面,点击阅读原文,或者下面链接,即可获取。欢迎star!
公众号guangcity
2019/12/16
1.1K0
内存管理之堆、栈、RAII
转:上网行为管理系统有哪些
让我们想象一个场景:一家大型企业的员工们在网络上分享大量敏感信息,同时还向外网提供服务。现在,我们想要确保网络资源得以有效利用的同时又不引发风险,那么该如何规避风险的同时确保网络资源的有效使用呢?这时上网行为管理系统就该派上用场了。那么,下面列举一些网络上有哪些好用的上网行为管理系统:
啵啵鳐
2023/10/12
4120
C++11/14/17中mutex系列区别
以上系列的对象都提供了加锁(lock)、尝试加锁(try_lock)和解锁(unlock)方法。
音视频牛哥
2022/06/16
1.2K0
设计模式之行为类模式PK
策略模式和命令模式相似, 特别是命令模式退化时,比如无接收者(接收者非常简单或者接收者是Java的基础操作,无需专门写一个接收者), 这种情况下, 命令模式和策略模式的类图完全一样. 但是两者还是有区别的:
烟草的香味
2019/07/25
4100
叶子相似的树
举个例子,如上图所示,给定一颗叶值序列为(6, 7, 4, 9, 8)的树。 如果有两颗二叉树的叶值序列是相同,那么我们就认为它们是叶相似的。 如果给定的两个头结点分别为root1和root2的树是叶相似的,则返回true;否则返回false 。
WindRunnerMax
2020/08/27
4410
如果疫情防控有「零信任」技术
疫情防控太难了,即使严格按照规定动作来做,病例还是一波接一波。 想来也是,因为: 在验证“你是健康的”环节: 核酸的结果不是马上就出来的,核酸检测达不到实时,为了平衡工作生活,只能要求一段时间内有核酸,现在大部分都是48小时,因为连24小时都会产生诸多不便。 核酸的检测准确性受制因素太多,采样位置、时间、病情轻重等都受影响。 所以,技术上其实没办法证明你现在/当下就是健康的。 在隔离阻断环节: 低风险的区域内部是默认信任的,一旦有病例,很容易造成传播。 不同风险区域之间的身份核实比较难,唯一的技术手段是
数说君
2022/08/25
3910

相似问题

RAII锁定条件

16

RAII类设计

20

锁定C#:奇怪的行为

15

与RAII相似的惯用短寿命局部物体

12

boost::scoped_lock RAII行为

25
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文