为 Word 和 Excel 文档添加了狡猾的远程模板注入器;独特的 Outlook 群发邮件宏
有朋友留言说,微软早就在Office里也支持JS了,比如Script Lab……其实关于Script Lab,二年前我们就聊过一次。今天就再大家详细聊一下,这主要包含了以下内容:
我们使用Excel VBA绝大多数情况都是在处理Excel的数据,一般都是直接读取Excel,也就是使用Workbooks.Open,随着VBA使用的深入,我们要处理的数据可能不局限在Excel里,有时候也会需要去读取外部的数据。
前期01:尝试:Script Lab,快速 Office 365 开发工具 //SL01
在执行下一段代码之前,如果需要暂停Excel VBA代码运行,该如何做呢?本文探索在Excel VBA中添加暂停的最佳方法。
Office 版本历经十几年的变迁,现已趋于成熟,但仍存在着新老版本交替使用的问题。Office 97-2003 Word 的文件后缀为 doc,新版本的 Office 文件后缀为 docx,包含宏的文档后缀为 docm。微软是不会允许将包含宏的文档命名为 docx,但是可以被命名为老版的 doc。例如一个 docm 文件,文件头的魔数是 504b0304(ZIP 文件的魔数),修改其后缀为 doc 后,文件头的魔数不变,且能够正常执行。而老版的 doc 文件头的魔数是d0cf11e(docfile 的十六进制表示 ^_^),所以我们可以通过文件后缀和魔数是否匹配来判断一个文档是不是恶意的。
本以为openxlpy可以读取,但查看openxlpy官方文档并没有找到相应的API,咨询了几个大佬,他们也没有处理过类似的问题。
在Excel中,公式是一项非常强大的功能,可以说,你能想到的,公式都可以给你做到。在完美Excel中,我曾分享过很多令人惊叹不已的公式,例如:
对于文件的其他一些操作,其实和我们平时用鼠标操作都是差不多的,主要就是创建文件夹、删除文件夹、创建文件、删除文件、文件/文件夹重命名、文件/文件夹移动等。 这些主要的功能Excel VBA都提供了相应的函数。
还是接着上前面的例子,公司突然要用系统来管理人员信息了,但是由于开发时间过于仓促,竟然没有从Excel导入的功能(好像挺说不通啊!)。你需要把统计好的10几万数据一个一个的输入到系统里(估计真有这种事的话你要辞职了)!
文章背景: 在VBA中,通过Dir函数,可以判断指定路径的文件是否存在等。此外,借助FileSystemObject对象,我们同样可以操作文件和文件夹。
Q:有一个文本文件,其内容包含很多以0开头的数字,如下图1所示,当将该文件导入Excel中时,Excel会将这些值解析为数字,删除了开头的“0”。
经常看到很多人会将他们的登录名/密码直接存储在VBA代码中甚至工作表中,这是很不安全的一种处理方式。例如,下面使用VBA来自动登录公司数据库的代码:
Excel(Microsoft office)是现在最常用的办公软件,主要涉及电子表格制作、数据处理、报表输出展示以及更高端的还有金融建模等;我们知道,在需要批处理多个Excel工作表以及工作簿的时候,需要用到一个自动化的利器:VBA。
虽然Python能干的事情,大部分编程语言都能干,但是功能比Python强大的,没Python简单好使;比Python简单好使的,功能没Python强大。
如果你只用VBA处理Excel的数据的话,一般都不会碰上编码的问题,但是一旦涉及到读取外部数据,就很有可能会碰上编码问题了。
在学习了《使用字典汇总数据》后,让我们再往前一步。假设我们的数据需要在多个列上进行检查。将A列中的数据链接到B列中的数据,以创建唯一标识符,希望基于2列创建汇总,而不只是前一个示例中所示的一个。假设供应商是Bob,Bob订购了Apple和Orange。订单分为6个不同行,但不是Apple就是Orange。
前段时间,我发了一篇关于《pdf里的表格数据也能轻松汇总了!》的文章,其中主要介绍了用Power BI直接汇总pdf文件中的数据的方法。
Q:在《VBA专题08: 使用VBA操作文本文件》中,我们讲解了如何使用VBA来创建、修改、读取文本文件等操作。我们在示例代码中创建的文本文件内容都是英文,因此一切顺利。然而,如果我们创建的文本文件是中文,结果如何呢?如下面的代码,创建一个含有中文内容的文本文件:
一套完整的BI报表应该至少具备以下四个条件: 条件一:能够批量处理有一定规模的数据; 条件二:能够保证数据的时效性及准确性; 条件三:能够将实际业务中所涉及的所有相关数据整合到一起,搭建统一的多维数据
BATCH也就是批处理文件,有时简称为BAT,是Windows平台上的一种可运行脚本,与*nix(Linux和Unix)上的Shell脚本和其它的脚本(Perl,Python)等是一样的,实质上就是一个文本文件,可是用特定的软件去解释的时候,就变成了可运行脚本。在Windows上,可运行脚本就是BATCH文件,也叫批处理文件,这是从DOS时代遗留下来的名字,意思就是把非常多命令放到一起来运行。它的扩展名是*.bat,双击便可直接运行,在命令行(CMD或叫做命令提示符)以下也能够当作一个命令来运行。由于这是Windows支持的东西,所以仅仅能在Windows平台使用。(特殊情况除外,不要钻牛角尖,没意思的)。比方著名的Windows垃圾清理小工具就是一个BAT批处理文件。
在分析测量数据时,通常以固定数量的数字显示结果,称为有效数字。数字的数量取决于测量本身的准确性。虽然Excel有几种方法可以对结果进行四舍五入,但没有一种方法可以将四舍五舍五入处理到指定的位数。
在看到知乎上有个问题: 我都会用Excel了,还有必要学Python吗? 这个问题大概率可以说明问这个问题的这位同学目前还没有遇到非Python不可的场景,之所以产生了学Python的念头是因为这两年Python实在是太火了,如果自己不学总觉得差点什么。但是学了一点以后又发现Python做的那些事情,我Excel也可以做,既然如此,我为什么还要费这么大劲去学Python呢? 为什么要学Python 大家在学一个工具或者一项知识的时候,一定不要为了学而学,这样不仅学起来很痛苦,而且很难坚持下去的。 那既然如
原文链接:https://mp.weixin.qq.com/s/OdCrUOsVAscqOjWaq2w8hQ
大家好,本节分享使用VBA程序将Excel文件内容写入txt文件,运行程序后,将Excel文件中A列的内容逐行写入txt文件
使用Excel VBA向MySQL数据库中添加和导入数据,可以使用ADODB.Connection和ADODB.Recordset对象来执行SQL语句。以下是一个示例,演示如何添加数据和从Excel导入数据到MySQL数据库中。
VBA还会存在多久?VBA会消失吗?我现在学VBA还来不来得及?什么语言会取代VBA?……这些都是老生常谈的话题,多少年前就有不少人在争论。然而,时至今日,VBA不仅没有消失,而且还活得很好。
今天给大家推荐一位VBA学习公众号-VBA说 VBA到底有多厉害? 其实除了不能生孩子,其余都行。 1 先说说VBA的趣(装)味(X)应用 ●利用Excel VBA爬取糗事百科图片 ●利用Excel
Excel是一款广泛应用于数据处理和分析的工具,而VBA(Visual Basic for Applications)是一种用于编程自动化Excel操作的语言。然而,对于非专业的Excel用户来说,VBA编程可能具有一定的难度。本文将探讨如何利用ChatGPT和VBA相结合,实现一键搞定Excel操作的全能助手。通过与ChatGPT进行对话,用户可以简单描述自己的需求,而ChatGPT则会自动生成相应的VBA代码,使Excel操作变得更加便捷高效。
👆点击“博文视点Broadview”,获取更多书讯 ▊ VBA与Python:当王者荣耀遇到卷王之王 VBA语言是VB的一个子集,具有简单易学、功能强大的特点。 上世纪90年代末至今,VBA语言被大部分主流行业软件用作脚本语言,包括办公软件如Excel、Word、PowerPoint等,GIS软件如ArcGIS、MapInfo、GeoMedia等,CAD软件如AutoCAD、 SolidWorks等,统计软件如SPSS等,甚至连图形软件如PhotoShop、CoralDraw等也使用VBA进行脚本编程。
作为一名Excel资深爱好者,手边当然离不开几本Excel技术书。这些优秀的技术图书不仅是我学习Excel技术的“领路人”,而且是我在解决Excel疑难时的“解答器”,并且时不时地翻阅它们,也给我带来撰写Excel技术文章的灵感。
在这个示例中,使用ADODB.Connection对象来建立与MySQL数据库的连接。将示例中的服务器地址、数据库名称、用户名和密码替换为自己的MySQL数据库信息。然后,你可以在打开连接之后执行各种数据库操作了。
本文为CDA金牌讲师李奇原创,转载请在本平台申请授权 随着大数据时代的到来,企业管理者对数据价值的重视度越来越高,他们渴望从企业内外部数据中获得更多的信息财富,并以此为依据,帮助自己做出正确的战略决策。在此种大环境下,缺乏洞察力的传统业务报表已经开始无法满足复杂市场环境中的企业决策需求,在很多企业中,“能否基于业务分析提供更具商业洞察力的数据信息”正在逐步取代“能否准确、及时地提供业务报表”成为考核业务人员能力的重要参考指标。为了能够提供更具洞察力的信息,需要业务人员强化以下两类能力: 强化所从事业务工作中
https://insights.stackoverflow.com/survey/2020#community-visiting-stack-overflow
要编写Excel VBA程序,必须知道对象。可以认为,VBA基于面向对象编程,这意味着VBA程序主要是在处理(或操控)对象。因此,我们要掌握ExcelVBA编程,必须理解:
👆点击“博文视点Broadview”,获取更多书讯 面向Excel数据处理自动化的脚本编程,目前主要有VBA和Python两种语言可供选择。 从上世纪90年代到目前,VBA一直是Excel脚本编程的主要工具。VBA语言具有简单易学、功能强大的特点,在长达几十年的时间里为提高Excel工作效率作出了贡献,也积累了海量的代码和学习资料。在这段时间里,Basic语言也一直是国内中学到大学教学首选的计算机语言。 随着网络时代的全面到来,以及大数据、人工智能等的兴起,Python语言在国内异军突起。Python语言
昨天,在推送了一篇文章《VBA编程练习05.在工作表中实现七段显示》后,有一位朋友留言:“尽是一些又冷又偏的理论,对实际工作用处不大的技术。希望多提供一些接地气、实用的技巧!”这不禁引起了我的反思:我这个微信公众号究竟是什么样的定位?还是先从自已学习Excel VBA的经历说起。
本次的练习是:给定一个单元格区域,要求使用公式得到该区域中出现重复次数最多的数据的重复次数。如下图1所示,在单元格区域A1:F1中,重复次数最多的数据是“完美Excel”,重复次数是3。
在Excel VBA对象模型里,我们说到了Excel VBA的专有对象,在前面几乎都是使用Excel VBA的专有对象,主要是因为我们操作处理的是Excel,其实VBA语言还有一些通用的对象(通用指的是比如在word里也有,在其他一些用VBA语言的应用程序都有的对象),这些对象在Excel VBA里用的还是比较多的,比如字符串对象那些功能,在用VBA实现Excel函数03:SUMIF已经使用过了。
面向Excel数据处理自动化的脚本编程,目前主要有VBA和Python两种语言可供选择。
Microsoft Excel是一款功能强大的电子表格软件,广泛应用于数据处理、统计分析和报表制作等领域。在Excel中,我们可以使用VBA(Visual Basic for Applications)宏编程语言来实现自动化操作。本文将重点介绍如何利用VBA批量创建和删除工作表,让你更高效地管理工作簿中的多个工作表。
程序员学习程序开发都喜欢以输出“hello world”为第一个程序,我们也学习一下这种模式,因为Excel VBA主要是操作Excel,所以我们的第一个程序目的:在A1单元格输入“hello Excel VBA”。
有时候,我们可能想要从Python运行Excel VBA宏,特别是当想要运行已有的Excel宏时,这很有用——甚至可以在不打开Excel文件的情况下执行这些VBA宏。
直到 90 年代早期,使应用程序自动化还是充满挑战性的领域.对每个需要自动化的应用程序,人们不得不学习一种不同的自动化语言.例如:可以用EXCEL的宏语言来使EXCEL自动化,使用WORD BASIC使WORD自动化,等等.微软决定让它开发出来的应用程序共享一种通用的自动化语言——–Visual Basic For Application(VBA),可以认为 VBA 是非常流行的应用程序开发语言VASUAL BASIC 的子集.实际上VBA是”寄生于”VB应用程序的版本.VBA和VB的区别包括如下几个方面:
在红蓝对抗或者国家某活动中,钓鱼是红队比较常见的攻击手段。通常的钓鱼手段包括exe文件的投递,自解压文件的投递,office系文件的投递等等。这几种文件投递的方式都能直接向对方电脑投递木马文件,但是现在的防守客户普遍使用了强有力的查杀手段,特别是针对exe等文件的查杀,这对木马文件的免杀提出了新的挑战(当然,免杀大佬请当我这句话没说过)。Office作为目前最常见的办公软件套件使用,因为它的普遍使用性可以作为我们从外网到内网的一个突破口,但是目前我在GitHub找到现有的一些项目在面对国内使用的三大杀软显得应付有些吃力,所以才有了自己编写一个工具进行bypass的想法。
每当有人发布关于 python 处理 Excel 数据的文章,总会有人只看了标题就评论:
大家好,本节将介绍Application对象的GetSaveAsFilename方法,以及介绍如何让Excel程序说话。
领取专属 10元无门槛券
手把手带您无忧上云