标签:VBA 有时候,工作簿中可能有大量的命名区域。...下面是一段简单的代码,它将列出工作簿中的所有定义的名称,并显示名称所指向的单元格区域。...'忽略错误 On Error Resume Next '遍历名称 For Each nm In Names '在列A中列出名称 wks.Range...("A" & Rows.Count).End(xlUp)(2) = nm.Name '在列B中列出名称指向的区域 wks.Range("B" & Rows.Count)...其中的错误捕捉语句以防止工作簿中没有命名区域。
本文将浅析GadgetToJScript的反序列化原理与在VBA中的利用。...而在VBA中的被检测的列表已有大佬整理了出来: https://github.com/synacktiv/AMSI-Bypass ? ? 当然,DDE与excel 4.0是不受amsi所保护的。...而amsi的bypass也早已是老生常谈的话题,例如outflank提出的 https://outflank.nl/blog/2019/04/17/bypassing-amsi-for-vba/ 或者是在...静态可过windows defender ,执行可以弹框。然后放入宏中 ? 然后我们换成之前的COM 对象来启动进程,弹出notepad ?...但这已不是宏需要考虑的了,而是在powershell中amsi patch的问题了,在前方的代码中加入amsi patch,即可然过wdf对ps的检查,得到Cs的beacon。 ?
大家好,今日我们继续讲解VBA数组与字典解决方案的第19讲:动态数组的定义及创建。在VBA中,数组可分为固定数组和动态数组,也称为静态数组和动态数组。我们之前所定义的数组,都是静态数组。...静态数组的特点是具有大小的数组。当我们事先知道数组的大小,我们可以直接声明为静态数组。固定数组定义方法:DIM 数组名(TO)。 但如果事前不知道数组大小时,怎么办呢?...在事前不知道数组的大小时,可以声明数组为动态数组,在需要指定数组大小时,再使用ReDim语句分配数组的实际元素的个数。...1、动态数组是可以改变大小的数组,通过在数组名称后附带空括号来声明,如: Dim arrSheetName() as String 2、在定义动态数组之后,必须使用ReDim来设置动态数组的上界和下界,...下面我们将通过一个实例来讲解动态数组的利用: 比如一个工作表的C列存储了学生姓名,现在我们需要把把有姓“王”的学生存储在数组arr中,预先我们并不知道C列姓王的学生有三十个还是五十个,所以,我们在定义时代码可以这样
文件操作 引用打开的工作簿 使用索引号(从 1 开始) Workbooks(1) 使用工作簿名称 Workbooks("1.xlsx") 创建一个 EXCEL 工作簿对象 Dim wd As Excel.Application...在 thisworkbook 中添加如下代码段: Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target...ActiveSheet.UsedRange.Interior.ColorIndex = 0 Target.Interior.ColorIndex = 6 End If End Sub 在单元格里回车...Range1, Range2) '取最大范围 选中单元格 / 区域 Range("1:1").Select '选中第一行 获取当前选中区域 MyWorkSheet.Application.Selection 数据结构...String arr() = Split(ws.Cells(a, b).Value, "-") alen = UBound(arr) - LBound(arr) + 1 判断单元格是否为空 判断单元格的
在 thisworkbook 中添加如下代码段: Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target...ActiveSheet.UsedRange.Interior.ColorIndex = 0 Target.Interior.ColorIndex = 6 End If End Sub 在单元格里回车...Range1, Range2) '取最大范围 选中单元格 / 区域 Range("1:1").Select '选中第一行 获取当前选中区域 MyWorkSheet.Application.Selection 数据结构...{ Do | For | Function | Property | Select | Sub | Try | While } 参见 Exit Statement (Visual Basic) 参考 VBA...Converting Data Types excel vba判断文件是否存在
本文来聊聊 MSIL 的基础知识,给一个 C# 的类标记了 static 之后和标记 static 之前,生成这个类的 IL 代码有什么不同 如以下的代码是一个默认的控制台程序 class Program...beforefieldinit KakawbaijairKacheberelere.Program extends [System.Runtime]System.Object 而如果给 Program 加上静态...extends [System.Runtime]System.Object 复习一下 IL 代码的知识 在 MSIL 里,采用 .class 表示这是类型的定义,类型定义的格式大概如下 .class...[类名] extends [继承的基类] 可以看到上下两个 IL 代码的不同在于,如果标记了 static 那 IL 将加上 abstract sealed 修饰。...和 C# 代码的含义相同,通过 abstract 表示此类型不能被实例化,通过 sealed 表示此类型不能被继承。因此这就构成了静态类的特点,不能被创建实例,也不能被继承
标签:VBA 这是一段非常好的代码,来自ozgrid.com,可以使用它来快速排序VBA中的数组。 代码如下: '对一维或二维数组排序....'二维数组可以通过传递适当的列编号作为sortKeys参数来指定其排序键. '函数传递一个引用,因此将对原始数组进行变异....matches s = Left(s, v.FirstIndex + padOffset) & Application.Rept("0", (padLen - Len(v))) & VBA.mid...sortCols Erase arr1 Erase arr2 Erase tmp On Error GoTo 0 sortArray = arr End Function 下面是一个如何处理包含数字的字符串排序的小演示...(可以使用自动筛选来查看默认排序与排序代码的结果对比): Sub smartNumberSort() Dim a, i& ReDim a(1 To 500) a(1) = "Key" For i
静态数据包括: 在namespace内定义的名字空间域变量 √ 在类中被声明为static的类域变量 √ 在函数中被声明为static的局部静态变量 × 在文件中被定义的全局变量(不管有没有static...修饰) √ 上面提到的非局部静态数据指的就是除去第3种情形之外,其他的1、2、4情形。...综上所言,本文的标题的含义是:如果在多文件中,分别定义了多个静态数据(不含局部变量),那么他们之间的相互依赖关系将会出现微妙的窘境。 什么窘境呢?...事情是这样的,由于静态数据会在程序运行开始时刻进行初始化(不管是指定初始化,还是系统自动初始化),并且C++标准没有规定多个文件中的这些静态数据的初始化次序,这就会带来一个问题:如果非局部静态数据相互依赖...因此,MF很有可能调用了一个未初始化对象的startup函数,这很尴尬。 避免这种情况做法也很简单,那就是定义一个函数,专门用来处理这些引发麻烦的多编译单元里的非局部静态数据。
在Bash中,可以使用各种命令和工具来实现复杂的数据处理和运算。...例如,可以使用awk命令计算文件中某一列的总和、平均值等。 使用sed命令进行数据处理和替换:sed是一个流编辑器,可以用于对文本进行替换、删除、插入等操作。...通过结合正则表达式,可以实现复杂的数据处理。 使用grep命令进行数据筛选:grep命令可以根据匹配条件筛选文本中的行。可以使用正则表达式来指定匹配条件,实现复杂的数据筛选。...使用Shell脚本编写自定义的数据处理和计算逻辑:Shell脚本是一种脚本语言,可以编写自定义的数据处理和计算逻辑。通过编写脚本,可以实现更复杂的数据处理和计算操作。...这只是其中一些常用的方法,还有许多其他的命令和工具可以用于复杂的数据处理和运算。根据具体需求,可以选择适合的方法来实现。
深度学习通过多层神经网络能够捕捉数据中的复杂模式,处理高维特征,特别适合于处理那些难以通过传统方法建模的复杂现象。...在接下来的内容中,我们将深入探讨复杂系统的特点、深度学习的方法,以及具体的应用实例,最后展望未来的研究方向和挑战。...3.1 气候建模 气候建模是深度学习在复杂系统中的一个重要应用领域。...4.1 数据挑战 复杂系统中的数据往往稀缺且不一致,这对模型的训练造成了困难。...此外,利用图神经网络处理复杂系统中的多维数据,可能会带来新的突破,尤其是在处理涉及多个交互主体的系统时。 结论 深度学习在复杂系统中的应用潜力巨大,能够为理解和解决复杂问题提供新的工具与方法。
VBA在多个文件中Find某字符的数据并复制出来 今天在工作中碰到的问题 【问题】有几个文件,每个文件中有很多条记录,我现在要提取出含有“名师”两个字符的记录。...文件如下: 【常规做法】打开文件--查找---复制---粘贴---关闭文件,再来一次,再来一次 晕,如果文件不多,数据不多那还好,如果文件多,每个文件的记录也很多,那就是“加班加班啦” 【解决】先Application.GetOpenFilename...,把找到的数据整行复制出来就可也。...完成一个文件,再找开一个文件…… 【VBA代码】 SubGetFile_Find_FindNext() Dim fileToOpen, x, total_file_path, m,title_row...Setmysht = ActiveSheet ' mysht.UsedRange.Clear title_row = 1 m = 0 i = 0 ss = VBA.InputBox
我特别喜欢的一项功能是能够轻松地创建一个自定义的Dataset对象,然后可以与内置的DataLoader一起在训练模型时提供数据。...通过使用内置函数轻松拆分自定义PyTorch数据集来创建验证集。 事实上,您可以在任意间隔进行拆分,这对于折叠交叉验证集非常有用。我对这个方法唯一的不满是你不能定义百分比分割,这很烦人。...至少子数据集的大小从一开始就明确定义了。另外,请注意,每个数据集都需要单独的DataLoader,这绝对比在循环中管理两个随机排序的数据集和索引更干净。...尽管如此,目前,PyTorch是我将来的深度学习项目的首选。 我鼓励以这种方式构建自己的数据集,因为它消除了我以前管理数据时遇到的许多凌乱的编程习惯。在复杂情况下,Dataset 是一个救命稻草。...您可以在我的GitHub上找到TES数据集的代码,在该代码中,我创建了与数据集同步的PyTorch中的LSTM名称预测变量(https://github.com/syaffers/tes-names-rnn
Java Stream API中的Collector接口是一个强大的工具,它允许我们自定义数据收集、转换和聚合的过程。 1....Collector接口的作用 Collector接口定义了数据收集、转换和聚合的基本操作,使得从Stream中收集到特定的数据结构或执行复杂的聚合操作成为可能。...在并行流处理中,如果有多个结果容器被生成,则使用combiner()方法将它们合并为一个容器。最后,通过finisher()方法将结果容器转换为最终想要的形式,并返回。 4....自定义Collector的使用场景 通过实现Collector接口来自定义复杂的收集器,以满足特定的数据处理需求。自定义Collector时,要实现上述五个方法,并定义如何收集、转换和聚合数据。...通过自定义Collector,创建特定的收集器,而满足复杂的数据处理需求。
静态成员在PHP中是怎么继承的? 静态成员,也就是用static修饰的变量或者方法,如果搞不清楚它们实现的原理,就很容易会出现一些错误。这次我们来研究的是在继承中静态成员的调用情况。...; } $b = new B; $b->show(); 之前的文章中,我们有说过self的问题。self仅仅只是指向当前这个类。注意,是类,不是实例化后的对象。...好了,有了这个基础之后,我们知道静态成员是和类有关的,和对象无关。那么以下的代码也就更容易理解了。...$d2->d . ';', PHP_EOL; 直接读代码能推导出输出的结果吗?其实只要掌握了上文中所说的原则,这段代码就很容易理解了。$c是静态变量,$d是普通变量。...通过类实例的add()方法进行操作后,$c因为是和类有关,所以不管是哪个实例对象,操作它之后都会是共享的。而$d作为普通变量,它的作用域仅限制在当前这个实例对象中。
最近在一次项目的重构中,原项目需要在静态方法中调用service,现在需要更换框架,service需要自动注入,无法再静态方法中调用 解决思路: 创建一个当前类的静态变量,创建一个方法,使用@PostConstruct...进行注解,被@PostConstruct修饰的方法会在服务器加载Servle的时候运行,并且只会被服务器执行一次。...PostConstruct在构造函数之后执行,init()方法之前执行。...方法中将当前service,调用时直接使用静态变量调用service 代码实例: @Component public class AutoLoginUtil { @Autowired
本文以 Louvain、FRAUDAR 和 CatchSync 这三种典型的复杂网络算法(基于图的挖掘算法)为例,结合实际业务场景,包括交易、社交和直播等互联网平台的核心业务,介绍复杂网络算法在平台业务安全中的应用实践...根据这样的定义,很容易可以得出以下4条性质: 如果其他条件不变,包含更高可疑度节点的子网络比包含较低可疑度节点的子网络更可疑。 如果其他条件不变,在子网络中增加可疑的边会使得子网络更可疑。...在移除一个节点时,只有与之相邻的节点会发生变化,那么这样最多产生O(|E|)次变更,如果找到合适的数据结构使得访问节点的时间复杂度为O(log|V|,那么算法总的时间复杂度就是O(NlogN)。...如何在这些静态的有向网络中识别可疑行为?一般来说,可疑的异常行为会形成一个紧密的子网络(dense subgraph),之前提到的FRAUDAR算法就是通过贪心策略找到这样的紧密子网络的。...自从笔者的团队将复杂网络算法(基于图的挖掘算法)上线以来,识别团伙作弊在风控中的作用越来越显著,为打击黑灰产提供了充分的技术支撑,而且帮助团队建立起一套较完备的风险分析技术体系,包含了主流的机器学习技术
完整的代码你可以看看这里 -- CodePen DEMO -- to the future By Jane Ori] 源代码还是非常非常复杂的,并且叠加了复杂的 SVG PATH 路径。...技巧 1:可以利用径向渐变,在一个矩形 DIV 元素中,通过径向渐变从实色到透明色的变化,实现一个半圆。...技巧 3:当你碰到大量重复有规律的线条,或者方块图形,你第一时间就应该想到在一个 DOM 中利用渐变而不是多个 DOM 去实现 好,至此,我们整个上半部分就实现了。...当你碰到大量重复有规律的线条,或者方块图形,你第一时间就应该想到在一个 DOM 中利用渐变而不是多个 DOM 去实现。...文中所有技巧在我过往的文章中都有非常高频的出现次数,对其中细节不了解的可以在 iCSS 中通过关键字查找,好好补一补。
这是一个很简单的技巧,但有时可能会给你的代码调试带来一些方便。...通常,在编写代码时,我们会在其中放置一些Debug.Print语句,用来在立即窗口中打印程序运行过程中的一些变量值,了解程序的运行状态。...一般情况下,Debug.Print语句每运行一次,就会将要打印的数据输出到不同的行中,如下图1所示。 ? 图1 那么,我们能不能将这些数据打印在同一行中呢?...将数据打印在同一行中,更方便查看结果,特别是有很多数据要打印时更是如此。 其实很简单,在Debug.Print语句中要打印的变量后面加上一个分号就可以了,如下图2所示。 ?...图2 可以看到,在立即窗口的同一行中输出了结果。这样,在立即窗口显示不下数据时,就不需要我们滚动向下查看数据了。对于数据不少、也不多的情况,可以试试!
业务需求 核酸采样登记数据分布在多个数据库中(减轻单数据库并发写入压力,按用户区域、终端等进行了划分),需要将分散的数据汇总起来后续做统一业务处理。...解决方案 使用mysql的FEDERATED,类似Oracle的dblink等,在汇总库中建立对各源库表的映射表,然后在汇总库中操作这些映射表,数据汇总。...实现步骤 业务表定义(在源和目标中定义一致的数据库) CREATE TABLE `sample_record` ( `ID` varchar(36) COLLATE utf8mb4_unicode_ci...在汇总数据库中建立各源数据库表的映射,映射为xxx_a\xxx_b\xxx_c等。...在汇总库中定义存储过程,按时间段抽取各源表的数据写入到目标表中,并删除源表中数据。
1.Split()用法 在VB.net中,Split 函数用于将字符串按照指定的分隔符分割成数组。...我们首先定义了一个包含水果名称的字符串 input。...2.Split(string,"、")如果没有"、"会出错吗 在VB.NET中,使用 Split 函数分割字符串时, 如果指定的分隔符在字符串中不存在,Split 函数并不会出错。...3.Replace()的用法 在VB.net中,Replace 函数用于替换字符串中的指定子串为另一个子串。...在这个例子中,我们定义了一个原始字符串 originalString,其中包含子串 "World"。
领取专属 10元无门槛券
手把手带您无忧上云