奇怪的不等于(≠) 最近,栈长用 IntelliJ IDEA 看源码时发现: ? 咦~这是什么鬼? Java 不等于的写法不是一直都是 != 么?什么时候可以写 ≠ 了??...Ligatures扩展 话说在源码中可以把 != 被显示成 ≠,那在正常的代码编辑器应该也能显示吧? 没错!!...栈长在设置菜单中根据 "ligatures" 搜索,发现有好几处设置 Font ligatures 的地方: ?...} if (n >= 1) { System.out.println(2); } } } 可以看到,显示归显示,代码复制出来还是正常的语法的...这个感觉就和 IDEA 中的智能显示如出一辙: ?
本文将浅析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/ 或者是在...然后放入宏中 ? 然后我们换成之前的COM 对象来启动进程,弹出notepad ? 但是直接生成的payload是会被windows defender所检测到的,需要自行混淆。...但这已不是宏需要考虑的了,而是在powershell中amsi patch的问题了,在前方的代码中加入amsi patch,即可然过wdf对ps的检查,得到Cs的beacon。 ?
图1 下面,我们分别使用公式和VBA来解决。...使用INDEX+SUMPRODUCT+MAX+ROW函数 公式如下: =INDEX($B$2:$B$10,SUMPRODUCT(MAX(ROW($A$2:$A$10)*($D$2=$A$2:$A$10)...得到一个由行号和0组成的数组,MAX函数获取这个数组的最大值,也就是与单元格D2中的值相同的数据在A2:A10中的最后一个位置,减去1是因为查找的是B2:B10中的值,是从第2行开始的,得到要查找的值在...组成的数组,由于这个数组中找不到2,LOOKUP函数在数组中一直查找,直至最后一个比2小的最大值,也就是数组中的最后一个1,返回B2:B10中对应的值,也就是要查找的数据在列表中最后的值。...图3 使用VBA自定义函数 在VBE中输入下面的代码: Function LookupLastItem(LookupValue AsString, _ LookupRange As Range,
TypeScript 提供了更强大的工具和功能,使开发者能够更轻松地编写可维护、可扩展的代码。本文将详细介绍 TypeScript 基础语法的各个方面,让您能够快速上手 TypeScript 开发。...变量声明在 TypeScript 中,可以使用 let 和 const 关键字来声明变量。...类型断言类型断言是一种告诉编译器某个值的类型的方式。可以使用 或者 值 as 类型 的语法进行类型断言。...装饰器装饰器是一种用来修改类、方法、属性或参数的声明的元编程特性。可以使用 @装饰器名称 的语法将装饰器应用到对应的声明上。...总结本文详细介绍了 TypeScript 的基础语法,包括变量声明、基本数据类型、函数、类、接口、泛型、模块、类型推断、类型断言和装饰器等方面。
Excel VBA学习之身份证号校检自定义函数 【问题提出】上次学习了一个用Excel函数的方法来解决这个问题,但是函数太长了,有时会忘记: =IF(LEN($B2)=18,IF(MID("10X98765432...",MOD(SUMPRODUCT(VALUE(MID($B2,ROW($1:$17),1)),说明!...$B$2:$B$18),11)+1,1)=RIGHT($B2,1),"合法","不合法"),"长度错误") 能不能简单一点,工作时不用那么辛苦的输入这个函数 【知识学习】 自定义函数的基本语法: 我们在...我们今天就从最基本的开始,先来学习下定义一个没有参数和一个只有一个参数的函数,通过最基本的例子来掌握自定义函数的基本语法结构。...自定义函数的语法结构: Function 函数名(参数1,参数2,……,参数n) 代码 函数名 = 代码执行的结果 End Function 语法很简单,看来难在了怎么得到结果的这段代码上。
而如果采用VBA语言,在Excel中根据需求编写一段简单的代码就能自动完成大量数据的整理工作。 1、以Excel 2007为例,如果要进行VBA编程,需要启用“开发工具” 选项。...并在该模块中添加一个名为Test的函数,如下所示: 在Sub 和End Sub间添加函数体,并保存。注意一定要将Excel文件保存为启用宏的工作薄(*.xlsm)格式。...3、然后点击开发工具选项中的宏按钮,打开如下对话框 选择Test,并点击执行。就能运行你所编写的Test函数。...基本语法: 1、给当前工作表的A1单元赋值10 ActiveSheet.Range("A1").Value = 10 或 Range("A1").Value = 10 或 ActiveSheet.Cells...10、实现单元格中内容换行的字符 Chr(10) 11、检测文件是否存在 Dir(完整路径的文件名) '文件存在则返回文件名,不存在则返回为空 12、从B列的最后一个单元格往上查找,并返回遇到的第一个非空单元格所在的行号
1.如何获的表格的行数 当然这里的行数是指有效使用的行数。 i = Sheets(2).[A65535].End(xlUp).Row 这里i就是你能够获得的第二张sheet中的所有有效行的个数。...2.在VBA里面使用Excel中的函数。 在函数前面加上Application.WorksheetFunction就可以了。
标签:VBA,Split函数 如果要统计某单元格中指定的某特定字符的数量,可以使用LEN/SUBSTITUTE函数组合的经典公式(假设字符串位于单元格B2): =LEN(B2)-LEN(SUBSTITUTE...图1 如果要统计单元格区域(示例中为单元格区域B2:B5)中包含指定的某特定字符的数量,可以使用下面的公式: =SUMPRODUCT(LEN(B2:B5)-LEN(SUBSTITUTE(LOWER(B2...图2 如果将上述两种情况使用VBA来实现,应该如何编写代码呢? 也很简单。...如果要统计单元格B2中字符“f”的数量,使用代码: UBound(Split(LCase(Range("B2")),"f")) 代码使用Split函数以字母“f”为分隔符对字符串拆分,拆分后获得的数组上限值与字符数相等...有兴趣的朋友可到知识星球App的完美Excel社群下载示例文档。 相关参考: 示例详解VBA的Split函数 Split函数与Join函数 欢迎在下面留言,完善本文内容,让更多的人学到更完美的知识。
标签:VBA 在使用VBA编写代码时,你可以不用强制声明变量,前提是在代码前面没有语句:Option Explicit,或者取消选择了选项中的“要求变量声明”。...然而,我们不提倡这种做法,因为会造成代码的混乱,当写错变量名时不容易找出哪里出错了。 在编写VBA代码时,声明变量并指出具体的变量类型是一种非常好的编程习惯。...这样也不好,因为这样的变量会在内存中占据更多的空间,并且在访问这样的变量以对其执行操作时往往会进行类型转换,从而导致代码运行变慢。...String Dim dbl As Double Dim sng As Single Dim lnglng As LongLong Dim vr As Variant 也可以在一行中声明多个变量,例如可以通过逗号分隔声明来缩短上面的内容...虽然这样做很方便,但存在的一个缺点是不如As语句后加上变量类型更加直观,不过,对于熟悉VBA的人来说,还是很方便的。 就这么多,你还有补充的吗?
文件操作 引用打开的工作簿 使用索引号(从 1 开始) Workbooks(1) 使用工作簿名称 Workbooks("1.xlsx") 创建一个 EXCEL 工作簿对象 Dim wd As Excel.Application...ThisWorkBook.Path & "/old.xlsx" newfile = ThisWorkBook.Path & "/new.xlsx" FileCopy oldfile, newfile 删除文件夹下的所有文件...Borders.Weight = xlThin .AutoFilter End With 获取或者设置单元格背景色 MyWorkSheet.Cells(i, j).Interior.ColorIndex 让某表格选中的单元格变成指定颜色...在 thisworkbook 中添加如下代码段: Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target...String arr() = Split(ws.Cells(a, b).Value, "-") alen = UBound(arr) - LBound(arr) + 1 判断单元格是否为空 判断单元格的
文件操作 引用打开的工作簿 使用索引号(从 1 开始) Workbooks(1) 使用工作簿名称 Workbooks("1.xlsx") 创建一个 EXCEL 工作簿对象 Dim wd As Excel.Application...在 thisworkbook 中添加如下代码段: Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target...dict.Items For i = 0 to dict.count - 1 key = k(i) value = v(i) Next ' 清空 dict.RemoveAll 参考:Excel vba...{ Do | For | Function | Property | Select | Sub | Try | While } 参见 Exit Statement (Visual Basic) 参考 VBA...Converting Data Types excel vba判断文件是否存在
Java 中的 3 个双引号 """ 是什么语法? 这是 Java 15 新出的,刷新你的认知!...文本块最早准备在 JDK 12 添加的,但最终撤消了,然后在 JDK 13 中作为预览特性进行了添加,然后又在 JDK 14 中再次预览,在 JDK 15 中,文本块终于转正,暂不再做进一步的更改。...3、Escape sequences(转义字符) 如下面代码所示: 我在代码中又增加了 \s、\n、\t 之类的转义字符,可以直接拿来用,双引号也不需要转义。...4、格式化参数 Java 15 之前格式化字符串中的参数需要使用 String.format 静态方法,感觉不是很方便,而在 Java 15 中新增了直接格式化字符串的方法: 对上面的 SQL 语句进行扩展下...四、结语 解读 Text Blocks(文本块)远比想象中要难很多,没想到一个文本块这么多细节,文中只是对文本块作了一个部分总结,并不是文本块的全部内容,反正暂时也用不到,大家简单了解即可。
;但我们未曾认真研究过这些特性的本质是什么,那么这篇文章,cxuan 就来为你揭开这些特性背后的真相。...因为 Java 代码需要运行在 JVM 中,JVM 是并不支持语法糖的,语法糖在程序编译阶段就会被还原成简单的基础语法结构,这个过程就是 解语法糖 。...所以在 Java 中,真正支持语法糖的是 Java 编译器,真是换汤不换药,万变不离其宗,关了灯都一样。。。。。。 下面我们就来认识一下 Java 中的这些语法糖 # 1.1 泛型 泛型是一种语法糖。...在 JDK1.5 中,引入了泛型机制,但是泛型机制的本身是通过 类型擦除 来实现的,在 JVM 中没有泛型,只有普通类型和普通方法,泛型类的类型参数,在编译时都会被擦除。...这个语法糖主要用来对数组或者集合进行遍历,其在循环过程中不能改变集合的大小。
比如 ANY:用于指示元素的主体内容为任意类型。 (子元素):指示元素中包含的子元素 对于子元素, ----可以定义子元素的名称,比如: <!...(1)#REQUIRED:必须设置; (2)#IMPLED:可选值,表示该属性可有可无; (3)#FIXED:固定值,通常语法为:#FIXED "固定值" (4)直接值:表示属性的取值为该默认值 定义属性示例...实体可分为:引用实体和参数实体,两者的语法不同 定义引用实体 概念:在DTD中定义,在XML中使用 语法: 引用方式(注意是在XML中使用):&实体名称; 注意:最后的“;”一定需要 DTD中定义: XML中引用: ©right; 定义参数实体(了解) 概念:在DTD中定义,在DTD中使用 语法:<!
今天跟大家分享一个在多条件求和方面特别厉害的函数——SUMPRODUCT。 ▼ 也许大家对sum函数都很熟悉,知道它强大的求和功能。...如果是用sumproduct函数来求的话,会是什么情况呢? ? ?...sumproduct函数语法详解: SUMPRODUCT(array1,[array2],[array3],[array4],…) 里面每一个arrayi代表一个数组,而且它支持的多个数组相乘。...本例中,公式SUMPRODUCT(B2:B8,C2:C8)分别代表B列的产品单价和C列的产品销量,数组之间用逗号(,)隔开。...当然,遇到需要三个 参数相乘求和的情况,sumproduct依然能够轻松搞定。 ?
TypeScript中的怪语法 如何处理undefined 和 null undefined的含义是:一个变量没有初始化。 null的含义是:一个变量的值是空。...Enable "strict" 或者 "strictNullChecks" 编译选项 在tsconfig.js中: { "compilerOptions": { "strict...用途 - 生成类的映射类型 - Mapped Types keyof的用途是很有趣的。...new()是描述构造函数的签名。所以在new()中,也定义参数。比如:{new(name: string): T}。 {new(): T}定义了一个返回类型为 T 的构造函数的Type。...root class of object type. type ObjectEmpty = {new(): {}}; // type ObjectEmpty = new () => {} 剩余语法
语法糖 语法糖方便了程序员的开发,提高了开发效率,提升了语法的严谨也减少了编码出错误的几率。我们不仅仅在平时的编码中依赖语法糖,更要看清语法糖背后程序代码的真实结构,这样才能更好的利用它们。。...泛型 与C#中的泛型相比,Java的泛型可以算是“伪泛型”了。在C#中,不论是在程序源码中、在编译后的中间语言,还是在运行期泛型都是真实存在的。...Java则不同,Java的泛型只在源代码存在,只供编辑器检查使用,编译后的字节码文件已擦除了泛型类型,同时在必要的地方插入了强制转型的代码。...stringList.add("oliver"); System.out.println((String)stringList.get(0)); } 自动拆箱/装箱 自动拆箱/装箱是在编译期,依据代码的语法...iterator.hasNext(); System.out.println(num)){ num = (Integer) iterator.next(); } 枚举 枚举类型其实并不复杂,在JVM字节码文件结构中,
标签: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
大家好,今日我们继续讲解VBA数组与字典解决方案的第19讲:动态数组的定义及创建。在VBA中,数组可分为固定数组和动态数组,也称为静态数组和动态数组。我们之前所定义的数组,都是静态数组。...静态数组的特点是具有大小的数组。当我们事先知道数组的大小,我们可以直接声明为静态数组。固定数组定义方法:DIM 数组名(TO)。 但如果事前不知道数组大小时,怎么办呢?...在事前不知道数组的大小时,可以声明数组为动态数组,在需要指定数组大小时,再使用ReDim语句分配数组的实际元素的个数。...下面我们将通过一个实例来讲解动态数组的利用: 比如一个工作表的C列存储了学生姓名,现在我们需要把把有姓“王”的学生存储在数组arr中,预先我们并不知道C列姓王的学生有三十个还是五十个,所以,我们在定义时代码可以这样...的内容转置填充,对于一维数组来说,中间是以逗号分隔的,如果想纵向填充,要进行转置,这可以结合之前工作表数组的表述来理解,逗号是分列,分号是分行。
领取专属 10元无门槛券
手把手带您无忧上云