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

《Python for Excel》读书笔记连载1:为什么为Excel选择Python?

如果你想想这是如何工作的,就会注意到一个单元格的值通常取决于一个或多个其他单元格,这些单元格可能会再次使用依赖于一个或多个其他单元格,依此类推。...没有重复的代码意味着更少的代码行和更少的错误,这使得代码更易于维护。 如果编写VBA,最常见的可重用代码是函数。例如,通过函数可以从多个宏访问同一代码块。...然而,这是一种危险的策略:Excel使引入难以发现的错误变得容易。例如,可以使用硬编码值覆盖公式,或者忘记调整隐藏列中的公式。 当告诉专业软件开发人员测试他们的代码时,他们会编写单元测试。...如果你查看图1-1中的货币转换工具,可以编写一个测试,检查单元格D4中的公式是否正确返回105美元,输入值如下:金额为100欧元,汇率为1.05欧元。这有什么帮助呢?...幸运的是,单元测试的概念非常简单,通过将Excel与Python连接,可以访问Python强大的单元测试框架。 单元测试通常设置为在将代码提交到版本控制系统时自动运行。

5.3K20

一起学Excel专业开发09:定义名称

图1 这样,就可以在工作表中或VBA中使用这个命名常量。要修改时,也只需在编辑名称对话框中对其进行修改即可。 在VBA中,命名常量的用途: 1.标识工作表。...在每个工作簿中定义一个唯一的命名常量,用来标识工作簿所在的程序。程序可以通过命名常量来判断其是否属于当前工作簿。 3.标识程序版本。...例如,在单元格D3中输入公式: =AboveCell 将得到其正上方单元格D2的值,如下图4所示。 ? 图4 上面的例子展示的是完全相对引用。...图5 此时,在列A以外的任意单元格中输入:=SameRow,都将返回相对应同一行的列A中单元格的值,如下图6所示。 ?...灵活使用相对命名区域,可以巧妙地解决动态数据引用的问题。 命名公式 可以对那些复杂且频繁使用的公式进行命名,更方便使用和维护。 此外,命名公式还可创建动态表。

1.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    VBA: 通过Application.OnTime定时执行程序(2)

    另外,提供了一份VBA代码,可以遍历各个单元格,假装对单元格内的内容进行编辑,借助Application.OnTime函数定时执行该程序。...1 旧方案 实际运行过程中发现,如果自定义函数的运行时间短,则没问题;如果文件夹内的文件较多,耗时较长的话,则可能会弹出如下的对话框: 出现报错的VBA代码如下: Sub RefreshCustomFunction...:代码中存在死循环或者长时间运行的操作,导致程序无法继续执行。...在本示例中,自定义函数需要遍历各个文件,通过比较,获取最新修改时间。所以文件夹中如果文件较多,则耗时较长,导致报错。...2 新方案 之前的策略是,遍历各个单元格,假装对单元格内的内容进行编辑,从而让自定义函数重新计算;现在采取的策略是,先在第一个单元格上填写公式,然后向下自动填充,在其他单元格内添加公式,从而让自定义函数重新计算

    84000

    Excel VBA解读(139): 用户定义函数计算了多次

    A3(其参数单元格A2的值显示为空),然后是单元格A2,接着又是A3,此时显示出其参数单元格A2的正确值。...(数组公式表达式等),并检查参数中的所有单元格是否包含公式和未计算任何单元格。...可以通过检查标准命令栏是否已启用来检测函数向导是否已调用用户定义函数。...条件格式公式中的用户定义函数 每次包含条件格式的屏幕部分被重新绘制或重新计算时,都会评估条件格式规则中的公式(可以通过在条件格式设置规则中使用的用户定义函数中使用Debug.Print语句来证明这一点)...结论 如果使用的用户定义函数执行的时间很长,则可以添加代码检查未计算的单元格以及通过函数向导调用的用户定义函数,来分析原因。

    1.8K30

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

    ---- 直觉理解运行机制 目前为止,我们没有编写一句 vba 代码,只是简单定义出一个加载数据的 Python 自定义函数,就可以在 Excel 上使用公式实现效果。...中的代码: 我们希望返回结果的前10行 修改后,保存一下此 Python 文件,在 Excel 上无须点击"导入函数"按钮,只要公式有刷新(比如修改公式引用到的单元格的值),就能看到最新结果: 只有...: 行5:设置 ret 装饰器的参数 index 为 False 即可 此外通过参数 header 也能控制是否输出表头 此次修改中,函数名字,参数数量没有变化,因此不需要点击"导入函数"按钮 ---...这问题由于 xlwings 在执行 vba 的方法时,会启动一个 Python 进程(只有首次运行的时候),然后加载 myproject.py 中的代码。但他没有设置启动目录。...才重新读取文件(现在是每次执行都加载) 锁定 xlwings 版本,如何能在没有安装 xlwings 的电脑上使用工具 你还有其他的功能建议吗?

    5.5K50

    简单的Excel VBA编程问题解答——完美Excel第183周小结

    14.如何将数组作为参数传递给过程? 数组名后加上空括号。 15.如何指定函数要返回的值? 通过将值赋给函数名称。 16.过程中的局部变量能否在调用过程之间“记住”其值?如果要这样,怎么办?...能够,通过使用Static关键字声明变量。 17.VBA可以识别通用格式的日期,例如2020/11/11。在VBA代码中,如何表明该值是日期? 通过将其括在#字符中。...同一字母的大写和小写具有不同的ASCII值。 22.如何从字符串开头提取一定数量的字符? 使用Left函数。 23.在VBA程序中使用哪个Excel对象引用的工作表单元格区域? Range对象。...包含工作表中所有已使用单元格的最小单元格区域。 26.如何在单元格中添加批注? 获取引用该单元格的Range对象,然后调用AddComment方法。...欢迎在下面留言,完善本文内容,让更多的人学到更完美的知识。 欢迎到知识星球:完美Excel社群,进行技术交流和提问,获取更多电子资料。

    6.6K20

    Excel实战技巧108:动态重置关联的下拉列表

    本文主要讲解如何使用少量的VBA代码重置Excel中相关联的下拉列表。...下面将介绍如何在第一个下拉列表中的值发生变化时自动重置与其关联列表的值,这里使用ExcelVBA执行此操作,使用了工作表对象的Change事件过程。...注意,默认的工作表事件过程是SelectionChange事件,每次更改活动单元格时都会触发该事件。...在这种情况下,最好使用工作表对象的Change事件并确保它仅在特定单元格的值发生更改时运行,而不是每次更改任何单元格值时都触发该事件过程。...图2 现在,我们想要在单元格C2中的值更改时,在单元格C6中显示“请选择…”,每次单元格C2中的内容更改时,单元格C6中的内容都会被重置。

    4.6K20

    Excel VBA解读(137): 让使用用户定义函数的数组公式更快

    本文主要研究使用用户定义函数的数组公式。 有两类数组公式: 单单元格数组公式输入在单个单元格中,循环遍历其参数(通常是计算的参数)并返回单个结果。...可以将VBA用户定义函数所花费的时间分成下列组成部分: 调用用户定义函数的开销时间。 用户定义函数获取将要使用的数据的时间。 执行计算的时间。 返回结果的开销时间。...每次的VBA读写调用都有相当大的开销,因此一次读取和写入大块数据通常要快得多。 因此,应该让VBA用户定义函数在单个块中尽可能多地读取数据并将数据尽可能大地返回到Excel。...而输入多单元数组公式做到了尽可能多地写入数据到Excel,最小化了调用开销,并且通常它可以一次读取数据并多次重复使用。 如何创建多单元格数组公式?...我们沿用《Excel VBA解读(133):编写高效的Function过程——让代码运行更快的技术》中的示例,创建自定义函数的数组版本AverageTolE函数,功能是找到除多个误差之外的数据的平均值。

    3.4K20

    Excel VBA解读(143): 在自定义函数中使用整列引用时,如何更有效率?

    学习Excel技术,关注微信公众号: excelperfect Excel用户经常发现在公式中使用整列的引用很方便,这样可避免每次添加新数据时都必须调整公式。...在VBA用户自定义函数中处理此问题的标准方法是获取整列引用和已使用单元格区域的交叉区域,以便用户自定义函数只需处理实际使用的整列的一部分。...下面的示例VBA代码处理交叉区域,然后返回输入区域中的行数和已使用区域中的行数的较小者。...这里存在两个问题: 获取已使用单元格区域可能很慢。 XLL接口没有直接访问已使用单元格区域的方法,因此必须通过单线程锁定的COM调用来获取它。 获取已使用单元格区域的速度有多慢?...另一种更复杂的最小化执行时间的方法是将已使用单元格区域内的行数存储在某个缓存中,并在需要时从缓存中检索它。其中最难的部分是确保已使用单元格区域行缓存总是为空(在这种情况下去获取数字)或包含最新数字。

    3K20

    【愚公系列】《AI智能化办公:ChatGPT使用方法与技巧从入门到精通》 024-ChatGPT的办公应用(ChatGPT在Excel中的应用

    提示词:生成VBA代码,实现以下功能:在上面的表格中,在A1:A6单元格区域增加复选框,同时与A1:A6产生单元格链接。...按下Alt + F11以打开VBA编辑器。 在VBA编辑器中,点击插入 > 模块,在打开的模块窗口中粘贴下面的代码。 按下F5运行代码,或者关闭VBA编辑器回到Excel,通过宏来运行这个脚本。...复选框的选中状态将反映在对应的单元格中(选中时为TRUE,未选中时为FALSE)。 请注意,运行VBA脚本和使用宏可能会受到Excel安全设置的限制。...如果代码运行不成功,请检查你的宏安全设置,并确保允许运行宏。 5.自动显示选中及未选中记录数量 提示词:计算选中的和未选中的记录数量,请用Excel公式表示。...计算选中(TRUE)的复选框数量 =COUNTIF(A1:A6, TRUE) 这个公式计算A1到A6区域内值为TRUE的单元格数量,即选中的复选框数量。

    14720

    这些掌握了,你才敢说自己懂VBA

    上周,我发了关于Excel VBA的第一篇文章后,社群里就砸开了锅 看到辣么多小伙伴们,辣么喜欢,我的干劲儿就更足了。...今天是这个系列的第2篇,我们用「如何利用VBA加减乘除运算」的例子,帮助大家理解VBA的一些基础概念。 基础很重要,正所谓“基础不牢,地动山摇”。...(1)青铜小白-符号运算 (2)铂金老鸟-公式运算 (3)王者大牛-代码运算 有经验的同学,看到这里,肯定嘴角上扬45度,“我用公式就能轻松实现,何必用VBA呢?”...不错,用公式确实能够实现上述案例的结果,但是,VBA拥有公式无可比拟的优越性: 第一,公式无法使用「按钮控件」; 第二,日常的工作场景一般会涉及加减乘除等综合运算,如果我们使用公式就会格外的复杂而难以控制...(2)宏的结构 (3)cells属性以及cells操作Excel单元格 (4)如何在Excel放置按钮,并关联宏 通过5步实现: 点选「开发工具」-「插入」-「按钮(窗体控件)」---> 鼠标变为

    48130

    VBA掌握循环结构,包你效率提高500倍

    在《变量》分享那篇文章,我们将这些变化的行号数字更改为「变量」,用x代替,程序被精简为这样: 那时,我们通过将「单元格B2」的值赋值给「变量x」,然后手动变更「单元格B2」的值,从而变更「变量x」的值,...「For xxx = xxx To xxx Step xxx」,表示的意思是「变量xxx」的值从xxx变化为xxx,每次增加xxx (2)循环内容 循环内容根据工作需求书写相关执行代码就好,一般都是循环的核心代码...因此,上述代码可以翻译为:「单元格J1」= 「单元格H1」* 「单元格F1」+50。最后,程序到单元格获取对应的值即可。...」的地方,由于此时「变量 x = 2」仍然符合「X 从 1 变为 10 每次增加1」这个区间,因此程序接着运行,一直等到「变量 x = 11」的时候,程序会跳出循环,执行下一个语句。...(别问我为什么,因为我经历过翻译自己代码的痛苦) 很明显,更喜欢右边的排版,因为它排版干净、代码从属关系清晰,更易阅读。

    29730

    VBA掌握循环结构,包你效率提高500倍

    在《变量》分享那篇文章,我们将这些变化的行号数字更改为「变量」,用x代替,程序被精简为这样: image.png 那时,我们通过将「单元格B2」的值赋值给「变量x」,然后手动变更「单元格B2」的值,...「变量X」的值从1变为10,每次仅增加1,即:x可以取1 2 3 4 ...10。...因此,上述代码可以翻译为:「单元格J1」= 「单元格H1」* 「单元格F1」+50。最后,程序到单元格获取对应的值即可。...我们可以看到此时程序自动返回「循环开始」的地方,由于此时「变量 x = 2」仍然符合「X 从 1 变为 10 每次增加1」这个区间,因此程序接着运行,一直等到「变量 x = 11」的时候,程序会跳出循环...(别问我为什么,因为我经历过翻译自己代码的痛苦) image.png 很明显,更喜欢右边的排版,因为它排版干净、代码从属关系清晰,更易阅读。

    1.6K00

    VBA变量5年踩坑吐血精华总结

    ,用于返回一个介于bottom(最小值)和top(最大值)之间的随机数,且每次Excel编辑后该公式都会自动刷新返回的随机数; 我们一起思考一下,这样一个需求用第02篇(todo文章传输门)分享的能够实现吗...是的,那么我们用VBA如何实现呢? image.png 我们观察发现:行号是变化的,而且是「正向递增加1」的规律。 在VBA中,我们将这种根据需要能够随时变化的称为变量。...:将等式右边的内容赋值给等式左边,可以类似于我们日常所理解的等号 那么,这个程序完整的代码(乘法测试是这个小程序的名称),就是: image.png 接下来,为了方便大家的理解,我们来模拟一下程序的运行步骤...F1的值为 28,单元格H1的值为30,计算二者之间的值 image.png (6)最后,将二者的乘积赋值给「单元格F1」,并执行值写入操作 image.png 通过,以上我们使用VBA中的变量使我们的程序更加的灵活...2.变量命名规则 案例:已知「单元格D3」为固定值10,在「单元格C3」输入任意数值,点击「查看答案」求得长方形的面积显示在「单元格E3」 image.png 那么,我们该如何写代码呢?

    1.7K00

    常见的复制粘贴,VBA是怎么做的

    标签:VBA 引言:本文学习整理自powerspreadsheets.com,非常清晰透彻地讲解如何使用VBA进行复制粘贴操作。...例如,通过限定指定目标单元格区域的对象引用,可以将单元格区域复制到其他工作表或工作簿。...例如,在本文包含的VBA代码示例中,源数据所在的单元格区域引用如下所示: Worksheets(“Sample Data”).Range(“B5:M107”) 这个引用不是完全限定的对象引用。...Excel功能区中的复制命令 在使用VBA代码复制单元格区域之前,看看Excel功能区中的“复制”按钮命令。...例如,在某些情况下,可能希望:复制包含公式的单元格区域,并在目标单元格区域粘贴值。 这正是上面例子中发生的情况。在这种情况下,可能只希望粘贴值(无公式)。

    12.3K20

    VBA还能活多久?——完美Excel第169周小结

    从在Excel 5中推出的第一个版本起,VBA的存在将近30年。无论你是否学习过编程,这都是一种非常容易学习的编程语言,并且能够快速应用到具体的工作场景中。 为什么学VBA?...更重要的是,宏录制器可以将你的操作转换成VBA代码,你可以将代码与操作相对照来学习VBA,而且这些代码不用修改或稍作修改就可以应用到类似的场景中,这又促进了你想更进一步学习VBA。...学会如何使用VBA,不仅可以更充分发挥Excel的能力,让你从不同的角度理解和使用Excel,而且会使你具备普通的Excel用户没有的更多技能。...(续) Excel小技巧45:2个工作表操作习惯,利已也利他 Excel公式技巧45:按出现的频率依次提取列表中的数据 Excel小技巧46:在单元格中输入连续数字的6种方法 资源分享:电子地图下载与拼接器...技术 连接满足条件的多个值并显示在一个单元格中 #VBA 复制文件到指定的文件夹并重命名 仅显示组成SUMIFS函数的结果的数据 同步多工作表指定区域的数据 快速给所选单元格添加前缀

    4.7K40

    这些掌握了,你才敢说自己懂VBA

    image.png 上周,我发了关于Excel VBA的第一篇文章后,社群里就砸开了锅 image.png 看到辣么多小伙伴们,辣么喜欢,我的干劲儿就更足了。...image.png 今天是这个系列的第2篇,我们用「如何利用VBA加减乘除运算」的例子,帮助大家理解VBA的一些基础概念。 基础很重要,正所谓“基础不牢,地动山摇”。...如何计算上述运算,并写入单元格E4里?...不错,用公式确实能够实现上述案例的结果,但是,VBA拥有公式无可比拟的优越性: 第一,公式无法使用「按钮控件」; 第二,日常的工作场景一般会涉及加减乘除等综合运算,如果我们使用公式就会格外的复杂而难以控制...(2)宏的结构 image.png (3)cells属性以及cells操作Excel单元格 image.png (4)如何在Excel放置按钮,并关联宏 通过5步实现: 点选「开发工具」-「插入」-

    3.8K01

    Jupyter Notebooks嵌入Excel并使用Python替代VBA宏

    %xl_set 魔术函数“%xl_set”获取一个Python对象并将其写入Excel。在Excel中是否有想要的数据框“ df”?...你甚至可以使用PyXLL的单元格格式设置功能在将结果写入Excel的同时自动应用格式设置。 -c或--cell。将值写入的单元格地址,例如%xl_set VALUE --cell A1。...return (a * b) + c 输入代码并在Jupyter中运行单元格后,即可立即从Excel工作簿中调用Python函数。 不只是简单的功能。...在Excel中使用Python而不是VBA的脚本 你是否知道在VBA中可以执行的所有操作也可以在Python中完成?编写VBA时将使用Excel对象模型,但是Python也提供相同的API。...尝试进行诸如获取当前选择和更改单元格内部颜色之类的操作。弄清楚如何使用Excel对象模型进行操作的一种好方法是记录VBA宏,然后将该宏转换为Python!

    6.4K20

    一起学Excel专业开发02:专家眼中的Excel及其用户

    工作表:用于程序数据的存储 在程序代码中,在程序代码处理中,经常要用到一些数据,而工作表就是一个天然的数据存放地,我们可以在工作表单元格中存放数字、文本、表格或图片,供程序使用,而VBA程序代码可以方便地访问这些数据...工作表:一种声明式编程语言 我们用程序员的眼光来看Excel工作表,单元格存放着变量的值,单元格地址就是变量,公式或函数就是语句,通过引用单元格来获取或者计算得到相应的值。...Excel工作表就是一个实时的语言编辑器,在工作表单元格中输入数据和公式后,Excel实时给出结果,并根据公式所依赖的单元格的变化实时更新数据。...Excel更擅长数字计算,VBA擅长通用的编程,将两者合理结合运用,可以开发出高效的应用程序。 4. VBA与用户窗体 VBA是一种专业的编程语言,内嵌于Excel中。...3.VBA开发人员:精通VBA,在其工作簿中广泛使用VBA代码,相信所有问题都能用VBA解决,但因为对Excel缺乏充分的了解,所以不能很好地利用Excel的特性。

    4.3K20
    领券