Web Analytics
yangyang

码农兼一个普普通通小青年

All Posts in 2022.4


为Excel插件增加OCR识别功能

在前面开发一个社区团购微信接龙报表自动生成的Excel插件这篇文章中,介绍了如何开发一个根据买菜供货菜单结合群接龙自动生成统计报表的Excel插件。在那篇文章里,是手动输入购物清单里的商品和价格的,其主要原因是上头给的就是图片,而不是Excel文件。 本文介绍了在.NET程序中如何使用OpenCVSharp4结合PaddleOCR来实现图片里文字和表格的识别,并以WPF和Excel插件的方式将OCR功能引入到程序中,极大的减轻了手动录入的工作量。 …

Excel Development VSTO OCR PaddleOCR PaddleSharp OpenCVSharp4

开发一个社区团购微信接龙报表自动生成的Excel插件

在上海疫情持续下,买菜成了居民生活的一大难题。为了阻止疫情传播扩散风险,政府暂停了商超的线下购物。我所在的奉贤区区政府组织了一些名为“满天星”的社区团购。我报名了本楼的社区买菜志愿者,工作就是根据居委提供了菜单,在本楼微信群里用微信接龙的方式收集大家的买菜需求,为了简化工作量,使用VSTO Excel插件的方法开发了一个报表生成工具,可以根据买菜接龙,直接生成各户居民购买物资的报表,这样极大减少了统计上报的工作量。同时也分享了做了两天社区团购自愿者的一些心得体会。 …

Excel Development VSTO community group-buy

解决WPF中ContextMenu绑定RoutedCommand时第一次无法执行的问题

WPF中RoutedCommand是一个非常常用的功能,他能够将某一命令绑定到多个控件上,比如同一个命令可以绑定到Button,Menu,ContextMenu上,这样避免了重复的代码。     但初次使用RoutedCommand时我就遇到了一个很奇怪的Bug,就是将右键弹出菜单ContextMenu的某一个菜单和窗体上的某个Button同时绑定到了某一个命令上。在程序初次运行时,ContextMenu里面的绑定了命令的菜单是灰色的,不可用,即使设置IsEnable=true,也不行。而Button却是正常的,但在点击Button执行一次命令后,ContextMenu里面的菜单就变得可用了。     在一顿搜索之后发现了这篇文章How to Solve Execution Problems of RoutedCommands in a WPF ContextMenu,完美的解决了这一问 …

WPF ContextMenu RoutedUICommand CommandManager FocusManager

WPF单例应用程序的两种实现

在某些场景下,我们需要应用程序只开启一个实例,本文介绍了WPF中单例应用程序的两种实现,一种是删除App.xaml,手写Main函数来进行启动调度,他的优点是性能相对较好,只需要定义一个Mutex即可,缺点是他放弃了WPF程序中App.xaml的一些默认功能,比如可以存放全局资源样式,没有App.xaml使得在某些情况下,其他的窗体除非手动引用资源或样式,否则得不到设计时支持,这两个缺点都可以通过代码或者设计时标签来回避。另外一种方法是保留App.xaml文件,注册Startup方法,在该方法里启动一个后台线程来监测多次打开的行为,当检测到试图打开多次时,将上次的应用打开,它的缺点是额外多增加了一个工作线程。相比第一种方法来说开销较大,但对于当今的CPU来说,多一个线程处理似乎可以忽略,并且这个线程里面使用的是WaitHandle,实际并不占用太多资源。 …

WPF Single Instance Application

SQLServer中使用TVP和SqlBulkCopy批量插入数据

在有些场景下,我们需要批量插入数据,本文介绍了SQLServer中的两种比较高效的批量数据操作方法,它们是TVP表值类型存储过程以及SqlBulkCopy,他们的共同点是通过传输DataTable作为参数,批量插入数据,不同点在于TVP方法需要SQLServer 2008及以上版本,并且需要预先创建表值类型和存储过程,SqlBulkCopy方法则更简洁,不需要额外创建类型或者存储过程。 …

SQLServer TVP SqlBulkCopy Dapper

在WPF的ViewModel中更新UI界面

凡是做UI界面,不管是Winform也好还是WPF,都只有一个UI线程,我们不能在UI线程中执行耗时的操作,因为这样会阻塞UI线程,是的界面变得卡顿,十分影响用户体验。本文以Prism的MVVM模式为例,通过两个场景: 耗时操作通过异步回调返回值和耗时操作直接返回值两种场景,介绍了如何在ViewModel中执行耗时操作,并更新UI界面。 …

MVVM WPF Prism UI Thread