首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

疫情期间竟然还有这种病毒?解密古老而又神秘的宏病毒

上世纪90年代,就有"宏病毒"出现,病毒制造者利用word的特性,文档内嵌破坏性的程序。不过,由于技术的限制,当年"宏病毒"并不能造成毁灭性的影响。...\使用快捷键Alt+F11可以打开vb编辑器,查看宏代码。 实战研究 如果遇到启用内容后,查看VBA编辑器,弹出了要求输入密码的对话框,使用VBA_Password_Bypasser进行解密。...使用VBA_Password_Bypasser打开这个文档文件就可以正常打开VBA编辑器了,而不需要输入密码。...最基础的水平上,我们可以使用 Empire 或 Unicorn 来创建一个 VBA 宏: (实际情况,使用empire可以成功反弹shell;使用Unicorn显示生成payload的代码版本不兼容office2016...生成vba代码: word操作 点击上方标签视图标签,该标签中点击宏按钮,弹出的对话框输入宏名字,然后单击创建按钮。

5.5K30
您找到你想要的搜索结果了吗?
是的
没有找到

(ExcelVBA编程入门范例)

很喜爱VBA,喜欢使用她对Excel操作实现所需的功能,更喜欢使用VBA控制Excel以及实现结果后的那种感觉。...图00-06:刚打开VBE编辑器的窗口 可以“工程资源管理器”双击任一对象打开代码窗口,或者选择菜单“插入——模块”或“插入——类模块”来打开代码窗口。...调试VBA代码 VBE编辑器的菜单,有两项与调试运行有关的菜单项,即“调试”菜单和“运行”菜单,它们提供了各种调试和运行的手段。我现阶段进行代码调试,常用到的有以下几个: ■ 逐语句。...可能存在问题的语句处设置断点(可通过相应代码前的空白部位单击,将会出现一个深红色的椭圆即断点),当程序运行至断点处,会中止运行。...(当然,对程序代码的调试有很多方法和技巧,留待以后对VBA进一步研究和理解更透彻后一并讨论。) 利用VBA帮助系统 如果遇到疑问或错误,可以利用Excel自带的VBA帮助系统。

4.1K20

Excel编程周末速成班第24课:调试和发布应用程序

同样,如果用于某些数值计算的代码产生不正确的结果,则也将其视为bug。由于实际上存在无限数量的潜在bug,因此无法列出或描述Excel程序可能出现错误。...该语句生效,必须显式声明程序的每个变量。如果尝试使用未声明的变量,则VBA会显示一条错误消息。这样可以防止漏掉拼写错误的变量名。...除了始终使用OptionExplicit外,还有以下准则可以帮助减少程序bugs: 如果你的程序包含很多代码,将其分成相对较小的过程。大型过程更容易出现bugs,并且发生bug更难修复。...可以使用多种方法来使用监视表达式: 可以监视其值。VisualBasic“监视”窗口中显示表达式值(定义监视表达式,此窗口会自动打开)。每当程序进入中断模式,显示的值都会更新。...可以程序的任何位置设置断点,以强制程序该点暂停。 当程序中断模式下暂停,可以单步执行代码以查找错误VBA的监视可让你在程序执行期间跟踪程序变量的值。

5.7K10

使用VBA复制文件:5个示例代码

标签:VBA,FileCopy方法 我们可以使用VBA来复制文件,这里介绍5个实现VBA复制文件的示例。...示例2:使用变量复制文件 示例1文件名包含在FileCopy语句中。然而,它们也可以作为变量提供。...示例4:VBA复制之前检查文件是否存在 FileCopy命令将覆盖文件,而不会显示任何错误。因此,复制文件之前,最好先检查文件是否已经存在。 下面的代码检查目标位置是否存在文件。...下面的代码构建在示例4的基础上,如果出现任何错误,也会显示一个错误消息框。...自动化复制文件可能会导致错误,下面是一些常见错误: 复制不存在的文件会触发错误:运行时错误’53’:找不到文件

2.9K50

Python让Excel飞起来:使用Python xlwings实现Excel自动化

接着,Excel按Alt+F11组合键,打开VBA编辑器。 VBA编辑器,单击菜单“工具->引用”,找到并选取“xlwings”前的复选框,如下图10所示,然后单击“确定”按钮。...右侧的代码窗口,输入以下VBA代码。...接下来,保存VBA代码,现在我们要在Excel工作表创建一个按钮。返回Excel界面,“开发工具”选项卡,单击“插入->按钮”,并指定刚创建的宏Rand_10。...图12 注意到,当键入函数,square实际上会显示函数列表——我们可以像使用Excel内置函数一样使用Python函数,并且可以将单元格引用传递到函数。...确保VBA编辑器菜单“工具->引用”中选取了“xlwings”,并将更改保存到相应的Excel文件。有时,当打开多个Excel工作表,我们可能会无意中将此更改应用于另一个文件

8.2K41

VBA专题10-14:使用VBA操控Excel界面之在功能区添加自定义库控件

查找并选择你想要的图像文件,并单击打开。 该图像文件的副本被插入,删除原始文件不影响插入的文件。 注意:图像文件文件避免使用空字符,否则不能正确地引用文件。 6....单击工具栏的Validation按钮检查是否XML代码错误。 9. 单击工具栏的Generate Callbacks按钮。...保存并关闭文件。 11. Excel打开文件。 12. 按Alt+F11键激活VBE。 13. 插入一个标准的VBA模块,并粘贴在步骤9复制的回调代码。 14....图2 代替上述第4步和第5步手工插入图像,可以通过使用VBA过程使用相同的图像填充库。通过赋VBA过程的名称到loadImage回调属性来实现。下面列出了XML代码VBA代码: ?...Excel\使用VBA操控Excel界面\04.

2.9K10

VBA专题10-6:使用VBA操控Excel界面之执行命令以及激活功能区选项卡的两种方法

一种是使用SendKeys方法模拟按键,就好像是手工按活动窗口中的键一样;另一种是使用XML和VBA代码。...SendKeys方法 例如,下面的VBA代码模拟按下ALT、A和ALT键: Application.SendKeys "%A%" 将上面的语句放在Workbook_Open事件,在打开该工作簿,将激活...XML和VBA代码Excel 2010及以后的版本) 激活功能区选项卡的另一种方法是使用XML和VBA代码。执行下列步骤: 1. 下载CustomUI Editor并安装。 2....保存并关闭该文件。 9. Excel打开文件。 由于Initialize过程仍然没有准备执行,因此会出现错误消息,单击“确定”。 10. 按Alt+F11打开VBE。 11....要激活特定的内置功能区选项卡,例如“数据”选项卡,使用下面的代码: myRibbon.ActivateTabMso "TabData" 如果要在打开工作簿激活“数据”选项卡,Initialize过程插入上面的语句

3.5K20

ExcelVBA从入门到精通——(1)实现第一个VBA程序

VBA简介&用途 Visual Basic for Applications(VBA),是依附在应用程序(例如Excel的VB语言。...如何打开VBA 1、打开“开发工具”功能(第一次使用VBA) 如果你是第一次使用VBA,需要打开“开发工具”功能。...文件——选项——自定义功能区——勾选开发工具 2、打开VBA的三种方式 (1)开发工具——Visual Basic (2)ALT+F11快捷键 (3)右键sheet页查看代码 3、VBA界面 写一个简单的...立即窗口” 如果你用过Rstudio写R代码或者Spyder写Python代码的话,“立即窗口”类似于控制台,能提示代码编译错误和进行实时计算。...1、打开“立即窗口” 视图——立即窗口 2、立即窗口输入代码直接作用于excel 选中一个单元格,然后立即窗口输入代码(不必定义Sub过程),敲击回车键执行: 可以看到执行后被选中的单元格出现了你的昵称

2.3K10

打破Excel与Python的隔阂,xlwings最佳实践

这个工具的一个特点是,你的操作最后都能转化成 pandas 代码 此工具界面完全使用 Excel 制作(大部分情况下不需要编写任何 vba 代码),后台处理使用 Python(大部分情况使用 pandas...打开 Excel 文件 myproject.xlsm(注意要启动宏): xlwings 页,点击 import Functions 的大按钮,意思是"导入 Python 文件的函数" 此时我们输入函数公式...---- 直觉理解运行机制 目前为止,我们没有编写一句 vba 代码,只是简单定义出一个加载数据的 Python 自定义函数,就可以 Excel使用公式实现效果。...首先,我们之所以能在 Excel 上输入公式出现我们的自定义函数,是因为在这个 Excel 文件,存在 vba 代码,定义了同名的方法: 从 vbe 界面可以看到,当我们点击"导入函数"按钮...这问题由于 xlwings 执行 vba 的方法,会启动一个 Python 进程(只有首次运行的时候),然后加载 myproject.py 代码。但他没有设置启动目录。

5K50

VBA: 隐藏模块中出现编译错误:的解决对策

文章背景: 最近发现有些办公电脑打开一些excel文件(xls格式),会弹出一个对话框,显示""隐藏模块中出现编译错误:"。...当代码与此应用程序的版本或体系结构不兼容(例如文档代码面向 32 位 Microsoft Office 应用程序,但它试图 64 位 Office 上运行),通常会发生此错误。...通过64位office软件打开早期的excel文件,如果代码存在早期面向32位office编写的VBA代码,可能会存在上述的编译错误。...2 更新旧版本的VBA代码 对于 Office 2010 版本之前(VBA 版本 6 和更早版本)编写的 VBA 代码,需要修改为 64 位 Office 版本运行,否则在 64 位平台上运行时会导致错误...只有 64 位版本的 Microsoft Office 运行 VBA 代码,才需要修改 VBA 代码

11K10

VBA专题10-21:使用VBA操控Excel界面之禁用和启用控件、组和选项卡

ThisWorkbook模块的SheetActivate事件处理代码: Private Sub Workbook_SheetActivate(ByVal Sh As Object) 'Excel...示例XML代码: image.png Excel打开该工作簿,自动执行Initialize回调和GetEnabledAttnSh回调。...Custom UI Editor中保存该文件,首次Excel打开文件,将会出现关于Initialize和GetEnabledAttnSh过程提示的错误消息,因为标准的VBA模块仍然没有这两个回调过程...End Sub 要基于其XML代码的id禁用(和启用)某自定义控件,现有的标准VBA模块或者新的标准VBA模块包括下面的代码: Sub EnableAll() Call RefreshRibbon...,活动工作表不是标准工作表禁用这三个控件,只需ThisWorkbook模块包括下面的事件处理代码: Private Sub Workbook_SheetActivate(ByVal Sh As

3.2K20

Excel VBA对象模型

,而使用VBA是在后台操作。...mod=viewthread&tid=849024&extra=page%3D1&page=1& 2、Application对象 你打开一个Excel(注意不要有其他的Excel文件打开了),然后进入到代码编辑器...打开后的东西,也就是Excel VBA对象模型里的最高级的Application。...天子觉得这样管理太累,自然就要分封了,他分封一个国,VBA里我们可以这样新建1个Workbook,立即窗口输入: Application.Workbooks.Add 这时候你能看到,出现了一个空白的工作簿...然后EXCEL.EXE读取那个文件硬盘上的数据,并解析数据放到了内存 解析过程也就是去创建1个树形的对象模型 解析过程会根据文件的情况创建Workbook、Worksheet对象,其实所谓的创建也只是在内存按一些规则来组织数据

2.2K31

Excel编程周末速成班第26课:处理运行时错误

学习Excel技术,关注微信公众号: excelperfect 主要内容: 理解运行时错误及其原因 如何在过程启用错误捕获 使用Err对象 编写错误处理代码 延迟错误处理 使用错误作为编程工具 运行时错误程序运行时发生的错误...提示:由于VBA过程的内容彼此独立,因此可以多个过程错误处理代码使用相同的标签。...执行数学计算的过程应注意溢出和零除错误,但是该过程可以忽略与文件相关的错误,因为该过程执行期间它们不会发生。 VBA程序,过程通常会调用其他过程。...但是,如果没有打开,则会发生错误。程序可以无法提前知道是否打开特定工作簿的情况下使用此功能。清单26-3展示了一个函数,该函数在打开返回对工作簿的引用,或者没有打开返回Nothing。...4.没有错误发生,Err.Number属性的值是什么? 5.错误处理代码,如何使用引起错误的语句恢复程序执行?

6.7K30

Excel插件-多工作薄合并工具之安装注意事项和下载地址公布

安装步骤 因插件是使用visualstudio的开发环境开发的,这种Excel插件有别于传统的使用VBA语言开发的Excel插件,需要对用户电脑有一些底层的运行环境的要求。...咋看是有些麻烦,但实质是更加安全、友好,用户环境搭建好的情况下,基本只需双击这样的动作就能打开使用,不需设置宏安全性、宏警告等VBA开发的插件所面对的问题,特别适合企业级别的开发使用。...最最突出的是此种VSTO方式开发的插件是Excel文档和实现功能的代码可以分离,对插件维护、升级、错误修复等等一些开发过程不可避免的问题使用VSTO的数据和代码分离技术,数据保存在用户电脑,代码开发者开发好重新发布...,用户可以无需担心升级、错误修复等原因而不得不把手头的Excel文件弃用,重新获取开发者最新的版本的Excel文件,然后再重头再来完成之前在前一版本里已经个性化做过的事情。...视频的双击打开工作薄的bug已经修复!! ?

82620

VBA专题10-20:使用VBA操控Excel界面之隐藏和取消隐藏控件、组和选项卡

可以启动(当Excel开启)动态设置值,可以在运行时改变它们的值(使元素无效后通过使用VBA回调过程)。...例如,下面的示例XML代码和在标准VBA模块代码在运行时满足某条件隐藏(和取消隐藏)“对齐方式”组: ? customUI元素包括带有Initialize回调过程的onLoad属性。...Custom UI Editor中保存该文件,首次Excel打开,会出现关于Initialize和HideAlignmentGroup过程的错误消息提示,因为这两个过程仍然没有标准的VBA模块中找到...打开VBE,标准VBA模块代码如下: Public myRibbon As IRibbonUI 'Callback for customUI.onLoad Sub Initialize(ribbon...注意,当打开工作簿,创建ribbon对象。编辑VBA代码可能销毁这个新创建的对象。试图使与销毁对象相关的控件无效是不可能的,唯一的办法是重新创建ribbon对象重新打开该工作簿。

7.7K20

干货 | Office文档钓鱼的实战和免杀技巧

EvilClippy.exe -gg macrofile.doc Stomp VBA(滥用P代码)VT 查杀 12/60 效果很好,过火绒 将来自文本文件fakecode.vba的虚假VBA代码放在所有模块...请注意,VBA项目版本必须与主机程序匹配才能执行P代码 EvilClippy.exe -s 1.vba macrofile.doc 参数说明:-s 参数是通过假的 vba 代码插入到模块,用以混淆杀毒程序...文档的URL 将DOCX解压后的内容再以存储模式压缩为ZIP 修改后缀名为DOCX,打开后即可实现远程注入宏文档 按照上述Word宏钓鱼方法制作,保存保存类型为 dotm , fish.dotm, 开启...利用过程: 新建一个excel文件,找到”数据”→”自网站”→”地址”,填写要抓取数据的网站url,选中想抓取数据的表单 点击导入 点击确定,即可成功导入 接下来利用IYQ打开计算机来看看效果 我们自己的服务器的网站目录下放一个...当受害者双击打开,默认会用Excel打开,弹出警告,点击启用 因为前面的iqy文件是用cmd执行的,所以会继续询问是否启动另一个应用程序,CMD.EXE.

6.4K21

【内卷到底】Excel催化剂免费提供VBA解密功能,除打开密码外,其余所有密码均可秒级破解

VBA密码破解,一般地插件里,都是收费方式提供,Excel催化剂,全功能免费,最新推出VBA解密功能,还要公开核心源代码,这免费程度够诚意了么?...密码相关的历史推文: 第26波-正确的Excel密码管理之道 第123波-批量创建或取消Excel文件打开密码 Excel催化剂开源第18波-工作表、工作薄保护破解 功能展示 使用方法很简单,点击菜单后...中途会跳出这个错误弹窗,选择是即可,原因是破解后的文件代码打开,不能屏蔽此错误,手动选择【是】后,程序另存为文件后,再手动打开文件就不报错了。...因本破解方法是使用07版格式的文件破解方法,故遇到03版本格式程序自动打开后转为07版本格式,再进行破解,破解后的文件名也是07版本的,但07版本兼容性更好,破解也只是为了看源代码,不影响使用。...当然最后的.NET语言当然是选择C#,没有C#,代码现成摆在面前,想抄也抄不动,例如本篇的VBA代码破解,也是从老外写的C#开源代码抄到手的。

2.6K80

Excel调用Python脚本,实现数据自动化处理

主要有以下三点理由: 如果你对VBA不算精通,你可以直接使用Python编写分析函数用于Excel运算,而无需使用VBA; Python相比VBA运行速度更快,且代码编写更简洁灵活; Python...xlwings和插件都安装好后,这时候打开Excel,会发现工具栏出现一个xlwings的菜单框,代表xlwings插件安装成功,它起到一个桥梁的作用,为VBA调用Python脚本牵线搭桥。...但xlwings解决了这个问题,不需要你写VBA代码就能直接在excel调用python脚本,并将结果输出到excel。...xlwings会帮助你创建.xlsm和.py两个文件.py文件里写python代码.xlsm文件里点击执行,就完成了excel与python的交互。 怎么创建这两个文件呢?...我们打开.xlsm文件,这是一个excel文件,xlwings已经提前帮你写好了调用Python的VBA代码。 按快捷键Alt + F11,就能调出VBA编辑器。

3.9K20
领券