而NCBI 的基因库中已经包含有这些的信息,但是只有一部分是整理可下载的。而剩下的一部分可以通过 genbank给出的位点信息来提取,个人能力有限,这里只做抛转之用。...from Bio import SeqIO def format_fasta(ana, seq, num): """ 格式化文本为 fasta格式 :param ana: 注释信息...format_seq += "\n" return ana + format_seq + "\n" def get_cds(gb_file, f_cds): """ 从...genbank 文件中提取 cds 序列及其完整序列 :param gb_file: genbank文件路径 :param f_cds: 是否只获取一个 CDS 序列 :return...会有详细信息展示,点击 fasta 链接来下载序列 ? 4.2 对于NC,NM,可以用下面的方式来实现 CDS 序列下载,同样对于样本量大的序列分析比较低效 ?
同样,如果用于某些数值计算的代码产生不正确的结果,则也将其视为bug。由于实际上存在无限数量的潜在bug,因此无法列出或描述Excel程序中可能出现的错误。...调试工具 几乎所有bugs都是由两个因素导致的——单独工作或组合工作: 程序执行接收到错误的路径。 一个或多个变量取不正确的值。 VBA的调试工具旨在跟踪这两种bugs的原因。...在中断模式下代码编辑 VBA使你可以在中断模式下修改代码。当你认为已发现问题并希望立即解决该问题时,此功能很有用。然而,进行一些编辑后,VBA无法从暂停位置继续执行,必须重置项目才能重新启动。...只需将鼠标指针停留在代码中变量的名称上,VBA就会弹出一个带有当前值的小窗口。如果这还不够,VBA提供了更复杂的监视工具。 VBA可以在程序调试期间监视任何变量或表达式的值。...大多数bugs是由于变量取不正确的值和/或程序执行分支不正确造成的。 可以在程序中的任何位置设置断点,以强制程序在该点暂停。 当程序在中断模式下暂停时,可以单步执行代码以查找错误。
前面说到的指针Pointer,其实主要是说了取地址函数。得到了变量的地址,只能赋值给Long类型,并没有指针的作用,无法根据这个记录了变量地址的东西来操作变量。...但能得到变量地址,就可以去查看变量的内存布局,从而深入了解类型。 VBA里数值类型Integer、Long那些,内存布局比较简单,无非是1个、2个、4个连续的字节。...而String类型是有点不一样的,有了指针Pointer讲到的取指针函数,我们就可以对String深入了解一下。 深入了解数据类型有什么用?...通过网上的一些资料和自己猜测: 变量本身占用4个字节,用VarPtr可获取地址p VarPtr那个地址p保存的值,指向了字符的地址,p-4地址处保存的是长度信息,4个字节 另外2个是p-6处的00 88...,是不是程序退出的时候VBA的垃圾回收能释放那个内存?
标签:VBA 图表和图形是Excel最好的功能之一,它们非常灵活,可以用来进行一些非常高级的可视化。本文可以作为在Excel中使用VBA绘制图表的指南。...本文中的代码示例演示了使用VBA处理最常见的图表选项,很好地利用这些代码,自动创建和修改图表。...注意,在Excel 2013中,对图表引擎和文档对象模型进行了许多更改,例如AddChart2方法取代了AddChart方法。因此,本文中提供的一些代码可能无法用于Excel 2013之前的版本。...创建一个引用ChartObject内的图表的变量: Dim cht As Chart Set cht = Sheets("Sheet1").ChartObjects("Chart 1").Chart 创建一个引用工作表内图表的变量...: Dim cht As Chart Set cht = Sheets("Chart 1") 现在,可以通过使用cht引用图表来为图表工作表或ChartObject中的图表编写VBA代码: cht.ChartTitle.Text
2.这些掌握了,你才敢说自己懂VBA 3.VBA变量5年踩坑吐血精华总结 4.VBA中重要的强制申明,谁看谁明白 image.png 我们先看上次分享的案例题目。...「Step」可以取正整数和负整数,也可以省略不写;当「Step」省略不写时,值默认为1。 b.「Next xxx」中的「变量 xxx」可以省略不写,但建议完整书写,不省略。...「变量X」的值从1变为10,每次仅增加1,即:x可以取1 2 3 4 ...10。...我们可以看到此时程序自动返回「循环开始」的地方,由于此时「变量 x = 2」仍然符合「X 从 1 变为 10 每次增加1」这个区间,因此程序接着运行,一直等到「变量 x = 11」的时候,程序会跳出循环...image.png (2)VBA代码排版 “帅气”VBA路,从Tab起步 image.png
2.这些掌握了,你才敢说自己懂VBA 3.VBA变量5年踩坑吐血精华总结 4.VBA中重要的强制申明,谁看谁明白 我们先看上次分享的案例题目。...「For xxx = xxx To xxx Step xxx」,表示的意思是「变量xxx」的值从xxx变化为xxx,每次增加xxx (2)循环内容 循环内容根据工作需求书写相关执行代码就好,一般都是循环的核心代码...「Step」可以取正整数和负整数,也可以省略不写;当「Step」省略不写时,值默认为1。 b.「Next xxx」中的「变量 xxx」可以省略不写,但建议完整书写,不省略。...我们来模拟一下上述「For循环结构」的程序运行过程: (1)程序读取「循环开始」语句「For x = 1 To 10 Step 1」 由于我们使用了「For循环开始」,并且严格规定了「变量X」的值从1变为...」的地方,由于此时「变量 x = 2」仍然符合「X 从 1 变为 10 每次增加1」这个区间,因此程序接着运行,一直等到「变量 x = 11」的时候,程序会跳出循环,执行下一个语句。
1、需求: 从身份证号里提取出出生日期、性别。 2、举例: 接着上一次的例子,表格汇总完成后,你又得到了一个任务,需要对表格的数据进行处理,需要增加出生日期、性别。...可是你一看表格,完了,没有收集出生日期、性别这些信息! 难道要重新收集一次? 3、代码实现 身份证编码是有规律的,只要知道了规律,我们就能够从中提取出自己所需要的数据。...县级市)的代码; 第7-14位数字表示:出生年、月、日; 第15、16位数字表示:所在地的派出所的代码; 第17位数字表示性别:奇数表示男性,偶数表示女性; 第18位数字表示:校检码 15位身份证规则:...所以,按照这个规则,我们只要提取出对应位置的数据就可以了,性别判断取第15位或者17位数字,再取2的余数就能够判断出来: Function GetGenderFromSFZ(strSFZ As String...从第一位到第十七位的系数分别为:7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 ; ' 2、将这17位数字和系数相乘的结果相加; ' 3、用加出来和除以11,看余数是多少
程序中的错误捕捉永远不会被激活。 不幸的是,Microsoft尚未提供有关对象内部捕获哪些错误以及将哪些错误传递给VBA进行处理的任何信息。...将这些数据类型用于对象引用(而不是使用特定的对象类型)使VBA无法提前知道对象的方法和属性是什么,从而为各种错误埋下了隐患。...只要数组索引可能超出范围,在尝试给数组赋值或从数组中读取数据之前,使用LBound和UBound检查索引值。 总是验证用户输入的数据。错误的常见原因是用户输入不正确的数据,例如在需要数字时输入字符串。...最新的错误号,如果没有发生错误,则为0。 Description。最新错误的简短描述;如果未发生错误,则为空白。 Clear。从对象中清除错误信息。 发生错误时,使用Err对象获取有关错误的信息。...任何后续的错误(在该过程中)都将被忽略,有关该错误的信息将放置在Err对象中。你的代码可以使用此信息来确定是否发生错误,以及发生错误采取的操作。
VBA中的数组只有很少的几个函数可以操作: Ubound 取数组的上标 Luound 取数组的下标 Filter 筛选一维数组 Join 将一维的String类型数组连接为1个字符串 Array...生成1个Variant类型的数组 IsArray 判断1个变量是否是数组 Erase 释放数组所占资源 VBA的数组功能比较的少,但是在JS中,数组也是一种对象,JS已经在这个对象上实现了很多的属性和方法...,编程过程中直接调用即可,使用起来就方便了很多: join 和VBA中的一样,连接为字符串,不需要一定是String类型 push 添加元素到末尾 pop 从末尾删除元素,这2个方法不需要使用的人去关注数组是否越界...1个数组构成新的数组 slice 创建子数组 ………… 有这么多的方法仅仅是因为JS帮忙实现好了,可以简单理解为在VBA中,也可以自己去实现这些操作数组的函数,然后调用。...的应该都知道,这个输出应该是(VBA里数组获取单元格的数据后下标是从1开始,JS中是从0开始): 行0 列0 value = $A$1 行0 列1 value = $B$1 行1 列0 value =
学习Excel技术,关注微信公众号: excelperfect 数组是一种常用的数据结构,可用来存储一组相同类型的数据,你可以将一个数组变量视为一个迷你的电子表格,通过引用数组中的位置来存储或者获取数据...下图1所示的示例是一个名为MyArray的一维数组,包含有6个元素。注意,数组的索引通常从0开始。 ?...如果调整数组大小的同时,想要保留之前存储在数组中的数据,则需要使用Preserve关键字,告诉VBA在增加数组存储容量时,保留原来存储在数组中的数据。...ReDim Preserve MyArray(i) MyArray(i) = rng.Value i = i + 1 Next rng End Sub 方法3:从带有分隔符的字符串中创建数组...PopulateArray5-2() Dim MyArray() As Variant '创建数组 MyArray = Range("A1:D3") End Sub 方法5:从表中提取数据直接创建数组
经常看到很多人会将他们的登录名/密码直接存储在VBA代码中甚至工作表中,这是很不安全的一种处理方式。...thespreadsheetguru.com展示了一种简单的方法,能够在运行时将用户名和密码带入VBA,而不会在VBA代码或Excel工作表中暴露这些敏感信息。...本例中,文件名是“个人信息.txt”,放置桌面上。...这样,VBA代码将从这个文本文件中提取信息并进行处理,下面是完整的代码: '作用:通过Excel VBA和文本文件来登录公司数据库Sub DatabaseLogin() Dim Username....txt" On Error GoTo 0 '确定登录信息(手工或自动从桌面文件中提取) If FilePath = "" Then Username = Application.InputBox
在VBA中,运行时错误发生的时候,会直接中断程序的运行,如果仅仅是程序的使用者,可能完全不会代码,那么出现这种中断程序的运行的状况,使用者就会不知所措了。...如果能够在代码里捕获错误,并给出提示信息,那么使用者即使不懂代码,也能根据提示信息解决一些问题。...,取一个合法的名字,在名字后面加上英文的冒号就可以。...上面程序的意思就是,在On Error GoTo ErrTest语句之后,一旦代码出现了错误,程序就会从出错的地方跳转到标签ErrTest,然后继续执行代码。...因为作为写程序的人,必须要考虑到使用者的情况,给使用者出现运行时错误是不应该的,所以写程序的过程中,一定要非常严谨,尽量在所有的程序中都加上错误捕获的代码。
直播中我提到一个现象,即大家往往倾向于将Power BI可视化做成数据看板式,即类似如下这种: 这是很自然的做法,毕竟BI本身赋予用户的能力就是可以主动地、轻松地从【任意维度】和【任意路径】进行数据分析...这种做法尤其适合于电子大屏(如流量监控、公司运营状况可视化)、报告者做动态演讲汇报、以及管理者自主地从看板中挖掘信息。它借助联动切片钻取等功能,可以突破静态页面限制,动态地拓展和提升信息数量和质量。...比如报告的用户(高层领导)无暇自行探索数据,而你又无法进行当面阐述汇报;又或者你需要呈现给那些对报告内容和领域一无所知的观众。...题外话,在Excel里用VBA也能实现这个需求,比如下图这个vba制作的仿NBA文字动态直播。...上图下划线的文字来源于经过计算的结果或从数据维度中提取的文字,其余文字为AI按自然语言语法(如英文)规则生成的串联语句。
大家好,本节将详细介绍VBA中的运算符,它们是VBA中的连接桥梁。 常用的运算符大部分是数学课本中学过的内容,但它们是VBA运算的基础,所以本节将作汇总介绍。...下面会分别说明VBA中的四种运算符,顺带说下通配符,最后介绍运算符的优先级,即不同种类运算符同时出现时的运算顺序。...整除\即两数相除取商的整数,如5\2=2。mod求模运算时指两数相除取余数,如5 mod 2 =1,经常用于判断奇偶性。...显示的内容需要变量和字符串连接,其中i、j和i*j都是变量或变量的运算,不需要加英文引号“”,而“X”和“=”都是字符串,需要英文引号。...运算符按运算的优先级由高到低的依次顺序如下图所示:(相同优先级的运算符,在表达式中出现时,按从左向右顺序运算即可。)
是的,那么我们用VBA如何实现呢? image.png 我们观察发现:行号是变化的,而且是「正向递增加1」的规律。 在VBA中,我们将这种根据需要能够随时变化的称为变量。...其实,「变量」这个概念,我们在初中都已经能够运用的出神入化了,比如: image.png 这里面,我们通常称x为自变量,能够取任何变化的数字,而y(因变量)就会得到相应的计算结果。...我们用x代替,那么程序就变为: image.png 我们又知道,变量x的变化是依据「单元格B2」内容的变化而变化,也就是: image.png [备注] 在VBA中,「=」专业术语是「赋值」 即...但是这样操作,有以下几点缺点: 1)程序写起来特别的长,非常容易出错; 2)代码不易维护,修改难度大; 3)VBA从内存中读取变量的时间要远低于读取单元格的时间; 因此,可以总结使用变量有以下好处(拿小本本记好...但是,大家需要注意给VBA中变量取名字 需要注意以下几点: (1)尽量使用有意义的名字,且尽量使用英文或拼音命名 一方面,变量命名有意义就是大家可以读懂,知道变量表达的意义,增强代码的可读性。
dropper和载荷与之前的版本非常相似,但作者修改了一些公开信息(如MUTEX名称,混淆密钥等),我们认为行动参与者之所以修改这些信息,是因为想要避免基于公共IOC的检测。...VBA 这个Office文档包含一个VBA脚本,以下是代码: ?...此代码的目标是文档的属性(“theme”,“company”,“type”,“comment”以及“Hyberlink base”),通过查看文件的属性,这些信息可以直接从Windows资源管理器中提取...提取的信息被组合在一起形成一个变量,其使用base64编码以获取被写入磁盘的Windows库。这个文件被命名为netwf.dat。之后该文件就会由rundll32.exe通过KipSvc导出执行。...VBA脚本的最后部分显示这两个文件的属性被设置为“隐藏”。此外,我们也可以看到两个VBA变量名:PathPid(可能是有效载荷的路径),PathPidBt(可能用于批处理)。
标签:VBA,用户界面 本文接上两篇文章: 在Excel中自定义上下文菜单(上) 在Excel中自定义上下文菜单(中) 上下文菜单技术和技巧 下面的内容展示了如何修改本文中提供的代码,以使过程更具灵活性...正如在这条语句中所看到的,要禁用上下文菜单上的控件,必须知道该控件的ID(idMso)。然而,这可能是一个问题,因为这些信息并不适用于特定上下文菜单上的每个控件。...小结 在Excel 97至Excel 2003中,可以使用VBA代码将控件添加到每个上下文菜单中,但无法使用RibbonX更改上下文菜单。...在Excel 2007中,可以使用VBA代码将控件添加到几乎每个上下文菜单中。但是,无法使用VBA更改某些上下文菜单,例如形状和图片的上下文菜单。此外,无法使用RibbonX更改上下文菜单。...在Excel 2010及后续版本中,可以使用VBA代码将控件添加到几乎每个上下文菜单中。使用VBA更改某些上下文菜单的限制与Excel 2007中相同。
语言的优点是语法规则简单 VisualLISP 引入面向对象的LISP开发环境 从1986年发布AutoLISP以来到现在的二十余年来,Autodesk公司推出了AutoLISP、ADS、VBA...怎样对AutoCAD进行二次开发 从AutoCAD 2.18开始推出AutoLISP开始到现在,我们所能使用的开发工具主要有:AutoLISP、VisualLISP、VBA、COM外部接口、ObjectARX...ARX最早是在AutoCAD R13中提供的,但在AutoCAD R14中,ARX就被ObjectARX所代替。...特别要强调的是,ActiveX与AutoCAD交互操作很慢,若需要在外部程序中一边运算一边交互操作的重复迭代,将耗费大量时间,如同死机 值得注意的是,从AutoCAD 2010版本开始,VBA不在随...中提供的新命令WebLoad来加载你的页面,也可以开发一个很小的桩Stub模块来加载你的页面。
image.png 前面的《Excel VBA:办公自动化》和大家分享了VBA常用的基础知识,就有同学留言问我:猴子老师,能不能出一个项目实战案例,可以把前面的知识都应用起来。...从上面的分析中,我们进一步明确了思路,也就是从一个表格中提取指定内容,然后将该内容写入另一个表格的指定位置。 下面我们将这个案例的VBA代码展示出来,然后对每一句拆解分析。...变量「i」用来循环每一行数据,变量「zhanhao」 「zhanming」 「summoney」用来储存从「基础数据」中提取的需要写入「票证模板」中需要的内容。...然后,我们将这些意思联合起来,用大白话说就是:程序调用工作表的计数函数,首先,计算表格1-基础数据中D列非空单元格个数,然后将计算的这个值「赋值」给左边的变量「totalrow」。...因此,这里仅是向大家展示一个思路,当我们遇到一些我们从见过的内容,我们要综合运用各种储备对其有一个大概的判断,做到学习灵活应对。 推荐:人人都需要的数据分析思维 image.png
1、数组特点 从文档中可以看到,数组的几个特点: 具有相同的内在数据类型 每个元素具有唯一的识别索引号 这2点很好理解,1个数组里面只能存放一种数据类型的东西,每个元素都能通过索引号找到。...Excel VBA提供了修改为1的方法,强烈建议不要用这个方法,尽量去习惯这个下标0。 (个人看法):这种设计应该也是为了照顾非专业人员吧,毕竟人还是习惯从1开始的。...不过以后程序写多了,你会发现从0开始在一些循环、取余数等等操作中还是非常方便的。...要使用数组中的某个元素也非常的简单,直接引用它的下标就可以,比如我们给下标10的元素赋值1000: Arr(10) = 1000 很简单方便,不过这是任何一个语言的数组都有的功能,在Excel VBA...3、举例: 继续说Function里面的例子,我们当时是用For循环从1到100的一个一个的读取单元格的数据来处理,这种处理方法在碰到数据量比较大的时候,你会明显感觉到程序的运行速度很慢,这是因为VBA
领取专属 10元无门槛券
手把手带您无忧上云