富文本编辑器,一般都是BS架构专利一般,好像百度有一个开源的比较出名,但无奈这些都只能用在JS上,在BS网页端开发上使用。像Winform开发的VSTO,只能羡慕的份。...在Excel催化剂的批量邮件功能中, 为了得到最好的体验,不止是不用依赖OUTLOOK的组件来发邮件(好像VBA的方案只能用outlook组件,用户电脑没安装outlook就不能用),同时为了让用户可以在邮件正文编辑区的使用体验和...邮件群发功能 这个第3方富文本编辑器控件,不单单可以在里面作一些格式的配置,还可以有打开html文件,直接从网页其他地方复杂内容直接粘贴和插入本地图片,有了这些能力,在发送邮件正文时,使用体验就非常棒,...群发邮件核心代码,用这个富文本控件,拿到其渲染后的html文件,发邮件当然有C#自己的轮子,也很好用。...所以VSTO和VBA开发,真的有一个本质的区别,VBA大不了最多用下系统的API函数,OFFICE的对象模型,但在VSTO的世界里,只要用心找,可以尽性地用尽一切世界上优秀的代码轮子。
我做了一个Outlook的加载项实现这个功能,但是试验证明部署兼容性还是有一些问题(在一同事的Win7 x64 + Office 2007 x86上安装后不能加载)。所以这里分享一下用宏实现的方法。...,为了保证后面的步骤能够顺利,我们可以先做一些准备工作: “文件 → 选项”,弹出Outlook选项页面(Outlook 2007以前的版本可能在“工具”下直接就有宏,可以跳到第3步)。...点击打开“开发工具”选项卡,并点击其下的“Visual Basic”(Outlook 2007 以前的版本中可能在“工具”下的“宏”子菜单里就有),如图4。...”并双击“ThisOutlookSession”,打开编辑器,然后把以下代码粘贴到编辑窗口中(图5): Option Explicit Private Sub Application_ItemSend...启用宏 重新打开Outlook,由于我们的宏没有进行数字签名,所以默认是没有启用的,启动时Outlook会弹出提示,请在弹出的提示框中点击“启用宏”(如图6,我的截图中第一项可用是因为进行了宏的数字签名
背景: 有台mac安装了office 2013 但是一直崩溃,所以卸载了,但是等他重新安装了office 的时候,发现使用outlook的时候,提示弹窗如下: ? 解决方法: 删除以下文件夹: ?...提示: 如果不能按照教程或者图片方法找不到文件夹,建议直接用Mac的搜索功能,搜索这个文件夹名,然后删除这文件夹。
如果说Office XP是我用得比较全的一个版本(除了Outlook没有怎么用,其他组件基本都对照帮助文档摸了一遍,还用FrontPage做出了人生第一个奇丑无比的网站,但其实对那些所谓的开发完全是一知半解...,半生不熟),那么Office 2003是我真正意义上开始较为深入使用的版本,尤其以Excel和Access这两个组件,结合当时的实际工作需要,我使用VBA开发了从简单到复杂的各种小应用。...其次,它开始支持使用Visual Studio 2005以及.NET Framework对其进行开发定制,这就引出了一个全新的开发工具VSTO——Visual Studio Tools for Office...这里就是我们熟悉的.NET编程的体验,可以用到几乎所有.NET Framework的功能,目前VSTO支持的开发语言除了VB.NET,还有C#。...必须提出的是,微软对于VBA和VSTO的支持将继续保留,它们有自己的优势,尤其是对于Office 应用程序自有功能的自动化、快速开发、在本地使用的场景。
此乃旧文,题目改一下,有点系统性,JSA助攻第一波:可以通过Application.Run接口,让外部程序或VSTO/ExcelDNA项目可以调用JSA的宏代码。...以下是历史内容: 在WPS的个人版上,默认只有JSA宏,没有VBA宏,虽说在VSTO/ExcelDNA项目里或者外部程序如C#/python等可以使用COM通信来调用WPS的COM开放的接口。...如果使用外部程序或VSTO插件可以调用这些接口,是比较完美的。例如使用RPA工具,可以全自动化地对其进行单元格图片插入,最后形成报告结果。...在VSTO里可以调出webshape网页控件等,非常广阔的应用场景。 现如今,还真可以了。稍有点曲折,但总算是可以做到在windows环境下实现调用JSA宏的愿景。...如何调用,答案和FreeScript类似,仍然使用了Application.Run方法,在外部程序或VSTO插件里,调用这个方法,同样可以运行JSA宏。
读作 goes to,是C#3.0的新内容; -....字段定义时设置{ get; set; }属性的作用: 主要是为了外部访问的安全性封装字段,get set你自己可以设置限制条件,尤其是wpf绑定时,没有get set属性,界面是更新不了的。...Lambda表达式是C#3.0的新内容,如果您之前学习的C#2.0,不认识也就不奇怪了。 给您举个例子。...附 C# 2.0 的匿名方法语法: Method m += delegate(int a, int b) { return a + b; }; Console.WriteLine(m(2, 3)); *...****************************************************************************** C#中 += (s, e) => 这些字符什么意思
跟AI学C#编程-007:do...while循环 在学习VB.net VSTO for Excel中,发现很多.NET库在C#中引用比较方便,所以学习一下C#, 努力加油..........在C#中,do...while循环如何应用,举例说明 回答1 在C#中,do...while循环是一种控制流语句,它允许代码块重复执行,直到满足指定的条件为止。...我们可以使用do...while循环来实现这个逻辑: int count = 0; bool validInput = false; do { Console.WriteLine("请输入一个数字...我们可以使用do...while循环来确保用户输入了一个在这个范围内的数字: int numberToGuess = 50; // 假设目标数字是50 int guess; Console.WriteLine...在学习VB.net VSTO for Excel中,发现很多.NET库在C#中引用比较方便,所以学习一下C# 如果对你有帮助,请转发给大家免费学习 学习记录 序 =====文章列表====== 1 C#
在WPS的个人版上,默认只有JSA宏,没有VBA宏,虽说在VSTO/ExcelDNA项目里或者外部程序如C#/python等可以使用COM通信来调用WPS的COM开放的接口。...反正WPS也就躺平了,在二次开发里有bug,不管怎么反馈,也是懒洋洋的,不当一回事。 通常情况下,使用COM接口来调用WPS个人版也足够了。...如果使用外部程序或VSTO插件可以调用这些接口,是比较完美的。例如使用RPA工具,可以全自动化地对其进行单元格图片插入,最后形成报告结果。...在VSTO里可以调出webshape网页控件等,非常广阔的应用场景。 现如今,还真可以了。稍有点曲折,但总算是可以做到在windows环境下实现调用JSA宏的愿景。...如何调用,答案和FreeScript类似,仍然使用了Application.Run方法,在外部程序或VSTO插件里,调用这个方法,同样可以运行JSA宏。
前面一种介绍了许多VSTO开发的插件一些功能和零散提到VSTO开发的一些好处,今天在这里来个180大翻脸,开始谈下VSTO开发插件的一些不足。...学习资料很匮乏,一开始想着VBA转VB.net,语法是同一母系,门槛不高,但入门后发现很难再有更多的资料介绍了,C#语言倒还好些,视频、书籍都比较丰富,但需要给自己一个决心,狠狠啃上个把月,才能入门成功...开发出来的VSTO插件,对用户的OFFICE版本有要求,一般需要OFFICE2007及以上才可使用。...开发自定义函数的利器,VSTO开发自定义函数在发布给用户机器使用时麻烦,要对注册表注册,需要管理员权限,但Excel-DNA开发的完全没有这些烦恼,用户双击即可打开使或进行加载项载入,下次打开Excel...免费,真正VSTO开发其实是要钱的,需要visual studio专业版才可以开发,社区版是不能开发的,可能这个原因,使国外的VSTO开发没有太火爆起来。
其实.NET中的信号量(Semaphore)是操作系统维持的一个整数。当整数位0时。其他线程无法进入。当整数大于0时,线程可以进入。每当一个线程进入,整数-1,线程退出后整数+1。...整数不能超过信号量的最大请求数。信号量在初始化的时候可以指定这个整数的初始值。...System.Threading.Semaphore类的构造函数的两个参数第一个就是信号量的内部整数初始值,也就是初始请求数,第二个参数就是最大请求数。...Semaphore:可理解为允许线程执行信号的池子,池子中放入多少个信号就允许多少线程同时执行。...2、当semaphore拥有的信号量为1时,Semaphore相当于Mutex 3、当semaphore拥有的信号量>1时,信号量的数量即可供多个线程同时获取的个数,此时可认为获取到信号量的线程将同时执行
通过一个demo来说一下backgroundworker的使用 上图使我们最终需要实现的效果,下来我们开始编码 声明backgroundworker并绑定事件 在注释中已经写出属性的含义和绑定事件的含义...} e.ProgressPercentage是调用bw.ReportProgress()方法时的第一个参数,e.UserState为第二个参数 RunWorkerCompleted 任务完成事件调用方法...//e.Result 获取异步操作结果的值,即DoWork事件中,Result设置的值。...RunWorkerAsync(50); 开始执行任务,参数50可以在backgroundWorker1_DoWork方法中通过e.Argument取得,在backgroundWorker1_DoWork中有使用...backgroundWorker1.CancelAsync();取消任务执行,实际上是修改了CancellationPending的值,false变为true 附上demo代码 链接:https:/
VBA的代码 这说明在Excel高级开发群体中,特别是VSTO、COM加载项开发群体中,还是守口如瓶的,仿佛越是高级的开发者,越对自己掌握的“核心”技术保密,希望Excel催化剂这一系列的开源文章对此风气有所好转...2.VSTO开发的确还是很冷门,没有进入专业开发者的视野中 对于工作表密码破解这些,肯定是OFFICE开发者的专业领域,就算国内不开源,找国外,也没找到多少,所以此篇简单开源,还是有此必要性的。...方式未能破解成功,印象中还有一个问题是不懂得如何改写回.Net的C#代码,看到的是一大坨的VBA代码,也看不懂。...,但VSTO仍是十分欠缺,但其实也不完成是欠缺,只要合理使用搜索引擎和官方帮助文档,还是可以找到够用的知识点使用的。...此篇简单地实现广大开发者广为熟知的功能,代码换成了C#的形式,可在VSTO上实现此功能,希望此代码段在愿意学习、查找的人手中能被找到并复用起来。
,今天抛砖引玉,拿几个加密类函数来讲说一下VSTO较VBA开发的一些优势所在。...题外话 本人也是从Excel的VBA语言入门了编程世界的,然后很偶然的机会接触到VSTO,并且在一位热心的网友一路的帮助下,算是入门了C#语言,现在可以灵活地用C#实现自己想要的一些小功能(大部分是抄百度和...就算微软自己的.Net Framework类库集,也只能在.Net语言中使用,而不能供VBA所使用。...例如今天介绍的几个加密函数,在.Net Framework类库里,直接有现成的代码,几乎可以直接调用的程度,对于一些非OFFICE环境内的功能实现来说,使用VSTO开发或C#、VB.Net开发,开发效率还是有很大的提升...Excel催化剂插件下载链接:https://pan.baidu.com/s/1kDtFkM5KZ4R1lAO0TO07AA 因插件使用VSTO开发技术完成,插件的安装需要电脑满足相关的环境配置才能运行
此篇提供一些简单的知识点,部分有代码段,部分只是操作界面即可得到,供VSTO新手们学习。...查找枚举型的完整命名空间 在录制宏中,得到的代码,虽然绝大部分是很容易改写成VB.Net或C#代码的,但有一个小问题是当录制出来的代码有枚举类型时,在VBA里的枚举是不带命名空间的,在VSTO里,是需要补全此命名空间的...ShrinkToFit = False .ReadingOrder = xlContext .MergeCells = False End With End Sub 将其改为VSTO...的.Net代码,有xlCenter、xlContext的枚举类型的问题需要补全。...对于我们OFFICE使用的颜色,就是Ole颜色,对应于VBA接口的Color属性值 一般来说在VSTO的.Net环境下,引用的颜色是标准.Net颜色,需要和OFFICE的颜色进行转换,转换的代码也异常简单
大家好,又见面了,我是你们的朋友全栈君。 以前学过的Socket,后来没怎么用过,就基本忘了,所以闲来时重新回顾学习一番....一.Socket的概念 Socket其实并不是一个协议,而是为了方便使用TCP或UDP而抽象出来的一层,是位于应用层和传输控制层之间的一组接口....双向的通信连接实现数据的交换,连接的一端成为一个Socket....二.网络通信三要素 IP地址(网络上主机设备的唯一标识) 端口号(定位程序) 有效端口:0~65535,其中0~1024由系统使用,开发中一般使用1024以上端口....传输协议(用什么样的方式进行交互) 常见协议:TCP(面向连接,提供可靠的服务),UDP(无连接,传输速度快) 三.Socket的通信流程 四.C#中Socket的简单使用步骤 第一步:服务端监听某个端口
本文长度为3661字,预计阅读10分钟 前言 上一篇发了一个视频,关于车辆通过系统的场景模拟,在这个项目中,主要想介绍一下使用中距离的读卡器对车辆上的RFID卡进行身份识别,其中读卡这块的核心就是用到了...EventHandler的委托和线程的处理,看了一下原来的C#文章中,以前没有介绍过EventHandler的委托,所以这篇简单先介绍一下这个,后面的文章会结合EventHandler的委托和线程做一个模拟当时环境小...EventHandler使用 # 说明 1 声明一个EventArgs的子类,传递参数 2 声明委托对象,执行方法,将方法绑定委托对象 3 开启EventHandler的委托 EventHandler...这个类主要是写了一个实现的方式,其中重写了start和stop的方法,及我们定义的DataReceived的的处理方式 ? ? ?...点击按钮初始化时,使用+=刚才定义的方法进行委托。
【OFFICE插件管理工具】因用户需求而生,在1230版本再增加了修复VSTO插件安装过程高频出现的type属性错误的功能。...功能说明 OFFICE插件管理工具,由此名字可知,其针对的对象,已经不局限于Excel催化剂单款插件使用,乃是扩充至OFFICE大家族的所有成员,如Excel、Word、PowerPoint、Outlook...一般来说,插件只需安装在当前登录用户下可使用即可,无需安装到本机所有用户均可使用,特别是现在主流的VSTO技术开发的插件,默认也只是当前登录用户下安装,仅对当前用户可用。...部分新电脑自带的微软OFFICE版本,多数属于ClickToRun模式安装和家庭学生版的OFFICE,是VSTO插件不能用的重灾区,后文也会谈到修复技术。 ? ?...经过复制后,经反馈是有效的,一般VSTO技术开发的插件,都因为此项的修复得以改善,正常使用。
功能说明 OFFICE插件管理工具,由此名字可知,其针对的对象,已经不局限于Excel催化剂单款插件使用,乃是扩充至OFFICE大家族的所有成员,如Excel、Word、PowerPoint、Outlook...一般来说,插件只需安装在当前登录用户下可使用即可,无需安装到本机所有用户均可使用,特别是现在主流的VSTO技术开发的插件,默认也只是当前登录用户下安装,仅对当前用户可用。...部分新电脑自带的微软OFFICE版本,多数属于ClickToRun模式安装和家庭学生版的OFFICE,是VSTO插件不能用的重灾区,后文也会谈到修复技术。 ? ?...经过复制后,经反馈是有效的,一般VSTO技术开发的插件,都因为此项的修复得以改善,正常使用。...喜欢使用本工具的,也多多帮忙传播下,让更多人能够使用上它。
1、对C#反射机制的理解 2、概念理解后,必须找到方法去完成,给出管理的主要语法 3、最终给出实用的例子,反射出来dll中的方法 参考: C#反射,MSDN编程指南 反射是一个程序集发现及运行的过程,通过反射可以得到...使用反射可以看到一个程序集内部的接口、类、方法、字段、属性、特性等等信息。在System.Reflection命名空间内包含多个反射常用的类,下面表格列出了常用的几个类。...在C#中,我们要使用反射,首先要搞清楚以下命名空间中几个类的关系: System.Reflection命名空间 (1) AppDomain:应用程序域,可以将其理解为一组程序集的逻辑容器...(包括程序集名,版本信息,语言文化,公钥标记)来加载程序集的,会加载此程序集引用的其他程序集,一般情况下都应该优先使用 这个方法,他的执行效率比LoadFrom要高很多,而且不会造成重复加载的问题(原因在第...这就是在第1点中提到的Load方法比LoadFrom方法的执行效率高的原因。另外,由于可能把程序集作为"数据文件"来加载,所以使用 LoadFrom从不同路径加载相同程序集的时候会导致重复加载。
领取专属 10元无门槛券
手把手带您无忧上云