百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Excel系统运维终极武器:5个工业级VBA代码曝光

wptr33 2025-03-11 22:03 10 浏览

1 系统更新状态检查器

Sub 更新检测()

' 获取最近20条系统更新记录

Dim updateQuery As String

updateQuery = "SELECT HotFixID,InstalledOn FROM Win32_QuickFixEngineering ORDER BY InstalledOn DESC"


With ActiveSheet.QueryTables.Add( _

Connection:=Array("OLEDB;Provider=WinMgmts;"), _

Destination:=Range("A1"))

.CommandText = Array(updateQuery)

.RowNumbers = False

.Refresh BackgroundQuery:=False

End With

' 高亮三个月前的更新

Range("B:B").AutoFilter Field:=2, Criteria1:="<" & DateAdd("m", -3, Date)

ActiveSheet.AutoFilter.Range.Interior.Color = RGB(255, 240, 240)

End Sub

2 进程黑名单管理器

Sub 危险进程拦截()

' 自动终止高风险进程(需管理员权限)

Dim psList As Object

Set psList = GetObject("winmgmts:\\.\root\cimv2").ExecQuery( _

"SELECT * FROM Win32_Process WHERE Name LIKE '%cmd.exe%' OR Name LIKE '%powershell.exe%'")


For Each proc In psList

If proc.Name <> "EXCEL.EXE" Then ' 排除自身进程

proc.Terminate

Cells(Rows.Count, 1).End(xlUp).Offset(1) = "已终止:" & proc.Name & " PID:" & proc.ProcessId

End If

Next

MsgBox "共拦截" & psList.Count & "个可疑进程!", vbCritical

End Sub

3 网络连通性测试仪

Sub 网络诊断()

' 批量Ping服务器生成状态报告

Dim servers As Variant: servers = Array("192.168.1.1", "10.0.0.2", "gateway")


For i = 0 To UBound(servers)

result = CreateObject("WScript.Shell").Exec("ping -n 1 " & servers(i)).StdOut.ReadAll

Cells(i + 2, 1) = servers(i)

Cells(i + 2, 2) = IIf(InStr(result, "TTL"), "在线", "离线")

' 可视化信号强度

Cells(i + 2, 3).Formula = "=REPT(""█"", RANDBETWEEN(1,5))"

Next

Columns("C").Font.Color = RGB(0, 176, 80)

End Sub

4 防火墙端口管控器

Sub 端口管理()

' 自动开关指定防火墙端口(需管理员权限)

Dim portRule As String: portRule = "规则名=允许SQL端口 协议=TCP 端口=1433 操作=允许"


' 删除旧规则

Shell "netsh advfirewall firewall delete rule name=""允许SQL端口""", vbHide


If Range("B2").Value = "启用" Then

' 添加新规则

Shell "netsh advfirewall firewall add rule " & portRule, vbHide

Cells(2, 3).AddComment "最后配置:" & Now()

End If

MsgBox "1433端口策略已更新!", vbInformation

End Sub

5 系统事件日志分析器

Sub 日志分析()

' 抓取24小时内系统错误事件

Dim eventLog As Object

Set eventLog = CreateObject("WScript.Shell").Exec( _

"wevtutil qe System /q:*[System[Level=2 and TimeCreated[timediff(@SystemTime) <= 86400000]]]")


' 结构化输出到Excel

With Sheets("错误日志")

.Range("A2:D1000").Clear

logData = Split(eventLog.StdOut.ReadAll, "")

For i = 1 To UBound(logData)

.Cells(i + 1, 1) = ExtractXML(logData(i), "EventID")

.Cells(i + 1, 2) = ExtractXML(logData(i), "TimeCreated")

.Cells(i + 1, 3) = ExtractXML(logData(i), "Computer")

.Cells(i + 1, 4) = ExtractXML(logData(i), "Message")

Next

End With

Columns("D").ColumnWidth = 60

End Sub

Function ExtractXML(strData As String, node As String)

' XML解析辅助函数

ExtractXML = Split(Split(strData, "<" node>")(1), "")(0)

End Function

相关推荐

文科生自学Python-生成简单的WORD文档

--天行健君子以自强不息,地势坤君子以厚德载物,学习编程成就更好的自己--Python语言简洁生动,特别适合文科生学习入门IT世界,用几十行代码就能够做一个完整的爬虫脚本,开发效率杠杠的!短时间内即可...

使用Python 爬取京东、淘宝等商品详情页的数据,避开反爬虫机制

以下是爬取京东商品详情的Python3代码,以excel存放链接的方式批量爬取。excel如下...

CV学习笔记(二十四):数据集标注与制作

最近在做一些数据标注的工作,虽然标注数据比较枯燥,但这也是每个做算法的工程师升级打怪的必由之路。使用一些合适的工具往往可以事半功倍,效率UP。一:数据标注流程二:数据处理的一些小代码1:重命名当得到这...

新手常见的python报错及解决方案(如何理解python报错信息)

此篇文章整理新手编写代码常见的一些错误,有些错误是粗心的错误,但对于新手而已,会折腾很长时间才搞定,所以在此总结下我遇到的一些问题。希望帮助到刚入门的朋友们。后续会不断补充。...

殊途同归python第5节:一键管理所有文档

Python自带的os模块,文件和文件夹的小管家,直接上代码importosa=os.getcwd()#获取当前路径,以字符串形式返回当前的绝对路径。os.chdir("动画片收...

1.文件夹的处理 OS(文件夹的操作方法)

os.getcwd()#当前目录os.listdir()#列出目录下的文件os.path.join()#拼接路径os.path.split()#拆分路径os.path.exists...

Linux下分析bin文件的10种方法(linux binary文件)

这世界有10种人,一种人懂二进制,另一种人不懂二进制。——鲁迅大家好,我是良许。二进制文件是我们几乎每天都需要打交道的文件类型,但很少人知道他们的工作原理。这里所讲的二进制文件,是指一些可执行文件,...

文科生自学Python-pandas交叉透视表降维变换

--心有猛虎,细嗅蔷薇,学习编程成就更好的自己--...

史上最全!近万字梳理Python 开发必备的 os 模块(建议收藏)

点赞、收藏、加关注,下次找我不迷路...

工作中必备的12个Git命令(常用git命令清单)

...

Undoing a git rebase(undoing a git rebase)

技术背景在使用Git进行版本控制时,gitrebase是一个强大的命令,它可以将一个分支的修改合并到另一个分支,使提交历史更加线性。然而,在某些情况下,我们可能需要撤销...

【干货】常用的Git命令有哪些?(git 常用命令行入门)

Git是一个开源的分布式版本控制系统,它被广泛用于软件开发中。在使用Git进行版本控制时,有许多常用的命令,本文将对这些命令进行详细的介绍。...

项目中使用 husky 格式化代码和校验 commit 信息

大家好,我是前端西瓜哥。今天我们学习使用husky工具,在commit的时候做一些风格的校验工作,包括commit信息格式化和文件格式化。githook和husky...

Git可视化极简易教程 — Git GUI使用方法

前言...

实际工作中 Git Commit 代码提交规范是什么样的?

...