昨天一个前端的朋友找我帮忙用excel提取代码中的汉字(字符串),可算费了劲儿了,他要提取的内容均在单引号中,但问题是没有统一的规律,同一个单元格可能存在多个要提取的内容,而且汉字中间也夹杂其他字符。...所以总结了一下提取汉字的几种情况。 一、用公式提取Excel单元格中的汉字 对于一个混杂各种字母、数字及其他字符和汉字的文本字符串,要提取其中的汉字,在Excel中通常可用下面的公式。...同样对于A6:A8区域中的字符串,在B6中用RIGHT函数即可: =RIGHT(A6,LENB(A6)-LEN(A6)) 如果汉字位于字符串的中间,可使用下面的数组公式。...返回Excel工作表界面,在B14单元格中输入公式: =提取汉字(A14) 即可取得A14单元格字符串中的所有汉字。 二、用公式提取引号(某2个相同字符)之间的内容 ?...(A2,"'",""))))-FIND("'",A2)-1) 在excel中,如何查询字符串的第N次出现位置,或最后一次出现位置,使用公式: 最后一次出现位置 =FIND("这个不重复就行",SUBSTITUTE
引言:本文的练习整理自chandoo.org。多一些练习,想想自己会怎么解决这个问题,看看别人又是怎样解决的,这样能够快速提高Excel公式编写水平。 本次的练习是:示例数据如下图1所示。...图1 现在,想根据列A中的数据对列B中的值汇总。例如,对于列A中的“A”来说,在列B中对应的值是:1、13、14、15、16、17、18,其和为94。...我们将单元格区域A2:A21命名为“D”,单元格区域B2:B21命名为“V”。 要求只能使用公式,不能使用VBA,仅能使用上述两个命名区域名称,不能使用填充功能填充空单元格。 请写下你的公式。...解决方案 公式1:数组公式。...…… 公式并没有给出详细的解析,有兴趣的朋友可以参照前面推送的有关分析公式的文章对这些公式进行解析,相信对理解Excel函数,编写公式解决问题会有很大的帮助。
有时候,我们需要从单元格数据中提取出满足条件的值。例如,下图1所示的单元格B3中的数据“NO13859724621”,我们想要得到相邻两个数字组成的最大的两位数。 ?...然而,怎么样使用公式获得这个值呢? 这就涉及到需要找到一种方法,从数据的开头开始,两个两个地取值,从而遍历整个数据,然后比较这些值,获取其中最大的值。...这样,我们使用下面的数组公式: =MAX(IFERROR(VALUE(MID(B3,ROW(A1:A100),2)),"")) 结果如下图2所示。 ?...图2 公式中: MID(B3,ROW(A1:A100),2) 从单元格B3中的第一个字符开始,按顺序依次获得两个字符组成的数值,如下图3所示。 ?...2.上述公式中,使用了ROW(A1:A100),假设单元格数据长度为100,其实可以使用下面的数组公式: =MAX(IFERROR(VALUE(MID(B3,ROW(INDIRECT("1:"& LEN
假设有如下Excel文件,其中第二个WorkSheet中数据如下: 其中D列为公式,现在要求输出该列公式计算的数值结果,代码如下: 代码运行结果:
幸好,输入的数据还是很有规律的,即都是数字加上物品名称,因此还是可以很方便地使用公式来得到结果。...在单元格D3中输入数组公式: =SUM(IF(SUBSTITUTE(B2:B19,D2,"")B2:B19,SUBSTITUTE(B2:B19,D2,"")+0))& " " & D2 在单元格E3...中输入数组公式: =SUM(IF(SUBSTITUTE(B2:B19,E2,"")B2:B19,SUBSTITUTE(B2:B19,E2,"")+0))& " " & E2 在单元格F3中输入数组公式...图2 注意,由于是数组公式,应该按下Ctrl+Shift+Enter键才算完成了公式,Excel会在公式两端自动加上花括号。...在公式中,我们人为地将数据中的物品名称替换为空,然后与原数据进行对比,那么那些不相等的数据自然就是替换的物品的领用数值。
标签:Excel公式 通常,我们会在工作表中放置查找表,然后使用公式在该表中查找相对应的值。然而,这也存在风险,就是用户可能会在删除行时无意识地将查找表中的内容也删除,从而导致查找错误。...如下图1所示,将查找表放置在列AA和列BB中。 图1 如下图2所示,在查找表中查找列A中的值并返回相应的结果。...然而,如果查找表的数据不多,正如上文示例中那样,那么可以将查找表嵌入到公式中。 如下图3所示,选择公式中代表查找表所在单元格区域的字符。...图3 然后,按F9键,此时会将公式中的字符转换为其所在单元格区域的值,如下图4所示。 图4 此时,直接按回车键,再将公式复制到其它单元格中,结果如下图5所示。...图5 如上图的公式中,花括号表示其内容是数组: {"A",60;"B",35;"C",50;"D",48;"E",30} 每个逗号表示应该移动到一个新列,每个分号表示应该移动到一个新行。
学习Excel技术,关注微信公众号: excelperfect 条件格式与公式相配合,往往能够发挥很大的威力,其中之一就是用来突出显示单元格。如下图1所示,在“新建格式规则”对话框中: 1....选择“使用公式确定要设置格式的单元格” 2. 在“为符合此公式的值设置格式”框中输入适当的公式 3. 单击“格式”按钮,设置想要的格式。 ? 图1 本文以交替突出显示所选单元格区域颜色为例来讲解。...图3 可以清楚地看到,公式中ROW()返回当前单元格所在行的行号;MOD(ROW(),2)返回行号除以2后的余数,要么是0(偶数行),要么是1(奇数行);将MOD(ROW(),2)与0相比较:MOD(ROW...如果是TRUE,则应用设置的格式,即示例中的偶数行。 同样,如果想为奇数行设置格式,则使用公式: MOD(ROW(),2)=1 结果如下图4所示。 ?...这样,可以使用公式: ISODD(ROW()+COLUMN()) 如果要求变换突出显示的单元格,可以使用公式: ISEVEN(ROW()+COLUMN()) 结果如下图8所示。 ? 图8
标签:Excel公式 当完成一个复杂的公式之后,确实很有成就感,然而当过段时间再来看这个公式时,你可能无法很快看出这个公式的运作原理,或者你当初是怎么写出这个公式的。...我们知道,在使用VBA编写程序时,可以在程序代码中添加注释,以便于无论什么时候或者谁都能够很快地理解程序。那么,在公式中,能否添加注释,让公式更加易于理解呢? 可以使用一点小技巧来达到这的目的。...图1 在Excel中,有一个N函数,将不是数值形式的值转换成数字,日期转换成序列值,TRUE转换成1,其他值转换成0。...也就是说,如果我们在公式中使用N函数,而传递给它的参数是文本的话,它会将文本转换成0而不会影响最终的结果。...因此,我们可以在公式中添加一些N函数,在里面包含公式运转原理的文本来解释公式而不会影响公式的结果。对于上述示例,使用N函数添加公式注释后的结果如下图2所示。
解决方案 公式1 可以试试下面的公式: =LOOKUP(9E+307,--MID(A2,ROW(INDIRECT("1:"& LEN(A2)-9)),10)) 该公式使用MID函数从单元格中的第1个数字开始依次取...10位数,共14个数字,这14个数字中,由于有空格的存在,所以除单元格中的10位数外,其余都是9位数。...然后使用LOOKUP函数在这些数字中进行查找,返回最大的一个数字,即单元格中的10位数。 公式2 试试下面的公式: =MID(A2,SEARCH(CHAR(10)&REPT("?"...,10)&CHAR(10),CHAR(10)&A2&CHAR(10)),10) 在单元格中搜索前后都是空格且中间是10位数的数字。...提示:可以使用“公式求值”功能,详细查看上述公式是怎么运行的。
学习Excel技术,关注微信公众号: excelperfect 很多时候,我们都可能想要对每隔n行中的单元格求和,其中n是一个整数。如下图1所示,每隔1行求和、每隔2行求和、每隔3行求和,等等。 ?...)) 偶数行求和的数组公式为: =SUM(IF(MOD(ROW($A$1:$A$15),2)=0,$A$1:$A$15,0)) 注意,本文中的公式都是数组公式,也就是说,在公式输入完成后要按Ctrl+Shift...+Enter组合键,Excel会自动在公式两边添加花括号。...对于每隔2行求和,即求第1、4、7、10、13行中单元格之和,使用数组公式: =SUM(IF(MOD(ROW($A$1:$A$15),3)=1,$A$1:$A$15,0)) 对于每隔3行求和,即求第1、...5、9、13行中的单元格之和,使用数组公式: =SUM(IF(MOD(ROW($A$1:$A$15),4)=1,$A$1:$A$15,0)) 我们可以得到一个规律,对于每隔n行求和(n>1),其一般公式
在Excel公式中,双引号用于指示文本字符串的开始和结束,例如: ="这是完美Excel公众号" 然而,假设需要在文本字符串中包括双号引,如何实现呢?...假如输入下面的公式: ="这是"完美Excel"公众号" 则会导致下图1所示的错误消息。 ? 图1 下面讲解几种实现方法,供参考。...如果要添加双引号的文本在单元格中,例如单元格A1中,那么可以使用&符来连接字符串,但是需要添加附加的双引号来指明每段文本字符串开始/结束。...因此,上面的例子可以写为: ="这是" &CHAR(34) & "完美Excel" & CHAR(34) & "公众号" 公式中,仍然使用双引号来指示文本字符串的开始和结束,但是使用&符和CHAR(34...)在公式结果中添加双引号。
如果希望进一步操纵某二维数组的元素,则需要使用这种技术。例如,由于某种原因,在某种情形下,需要将二维数组中的每个元素传递给一个或多个参数进行进一步处理。...这样,结果数组中任何额外的不配对的单元格都将填充为#N/A。 在某些情况下,我们接受其中的数组被“重新定义维数”,即便使用错误值填充,前提是我们随后可以根据需要对结果数组进行操作。 继续!...在继续刚才的MID函数示例之前,我们以另一个示例来解释。假设在单元格A1:E10中的数据如下图2所示。 ?...根据其定义,列向量当然是一维的。这里使用的技术请参阅《Excel公式技巧03:INDEX函数,给公式提供数组》、《Excel公式练习44:从多列中返回唯一且按字母顺序排列的列表》。...0)) 注意,上述公式结构使用了函数T,因此要求单元格区域A1:E10内的值是非数字的。
Excel公式与函数非常强大,往往能够实现你认为不可能的需求。例如下图1所示的例子,我只想求单元格区域B5:F9中对角线单元格中的数值之和。 ?...图1 也就是: B5+C6+D7+E8+F9=10+20+30+40+50=150 可以使用数组公式: =SUM(B5:F9*(ROW(B5:F9)=COLUMN(B5:F9)+3)) 结果如下图2所示...图2 这个公式很简洁但有点特别,其特别之处是后面的+3。为什么呢?...因为我们要求的是对角线上的单元格数值之和,对于矩阵来说,对角线上的行列号相等,在本例中,行号从第5行开始至第9行,列号从第2列开始至第6列,相差3,所以将列号+3,使行列号相等,从而能够获取相应的数值。...公式中, B5:F9 将解析为一个5行5列的矩阵: {10,0,0,0,0; 0,20,0,0,0; 0,0,30,0,0; 0,0,0,40,0; 0,0,0,0,50 } 而ROW(B5:F9)将解析为列矩阵
这个数字:9.9999999E+307,我们经常会在公式中用得上它。这是一个神奇的数字,在查找数值时能够发挥很大的作用。本文介绍的就是这个数字的使用技巧。...9.9999999E+307是Excel能够识别的最大数字,它通常与LOOKUP函数或MATCH函数结合使用,以查找列/行中的最后一个数字条目,或分别查找行/列中数值的最后一行行号/列号。...在本示例中,LOOKUP函数查找最后一个小于或等于查找值9.9999999E+307的条目,类似的规则或MATCH函数返回行号。...因此,要查找列中的最后一个数字条目,可以使用: =LOOKUP(9.9999999E+307,A:A) 或者从行中返回最后一个数字条目: =LOOKUP(9.9999999E+307,1:1) 类似地,...要获取数字条目的最后一行,使用公式: =MATCH(9.99999E+307,A:A) 或者,对于行,使用公式: =MATCH(9.99999E+307,1:1) 有兴趣的朋友,可以仔细研究,在需要时可以将此技术进行灵活运用
在使用Excel时,我们肯定会使用公式。这些公式要么会引用其他的单元格,要么会被其他单元格引用。下面我们先看看这两种情况,如下图1所示。 ?...在单元格A6中,使用公式:=SUM(A1:A5)求单元格区域A1:A5的数值之和,其中单元格A1、A2、A3、A4、A5都称为该公式所在单元格的引用单元格。...在单元格C1中,使用公式:=A6+B1,求单元格区域A1:A5与单元格B1中的值之和,很明显,单元格A6和B1都是该公式所在单元格的引用单元格,但该公式实际使用的一些值来自于单元格区域A1:A5,该单元格区域中的单元格称为间接引用单元格...单元格C1中的公式也间接使用了单元格区域A1:A5中的每个单元格,因此单元格C1也是这些单元格的从属单元格,也称为间接从属单元格。...按Ctrl+Shift+{键,选择当前工作表中公式单元格的所有引用单元格(包括直接和间接的引用单元格)。 4. 在公式单元格中按F2键,Excel会使用不同颜色显示该单元格直接引用的单元格。 5.
图1 有一些附加条件: 排除包含数字的任何单元格 排除空单元格 排除包括公式结果为空字符串的任何单元格 在图1所示的示例中,满足条件的文本单元格共5个。...理解Excel将什么考虑为“空” 需要弄明白的是,空字符串与空单元格不同。空单元格中没有任何内容,空字符串是不显示任何结果的公式的结果。...这通常是通过使用两个双引号来实现的,它们之间没有任何内容: =IF(A9="Ok",C9,"") 两个双引号之间被称为“空文本”,在单元格中不会显示什么但会作为数据被统计。...如果使用ISBLANK函数测试包含空文本的单元格,返回的结果将是FALSE,这意味着Excel不会将空文本作为真正的空单元格。...通常,对于COUNTIF函数的条件判断使用“不等于”(即“”),但是在本示例中,我们将反转小于/大于符号的顺序,写作“>公式如下: =COUNTIF(B4:B14,"><") 该公式仅统计了包含文本的单元格
首先读取 Excel 文档 sum.xlsx 并获取活跃工作表;其次在单元格 A5 以及 B5 中分别写入公式 =SUM(A1:A3) 和 =SUM(A1:A3,B1:B3);最后对 Excel 文档进行保存...B5 单元格的值为 A1,A2,A3,B1,B2,B3 单元格的值相加。 1.2 VLOOKUP 使用 VLOOKUP 可以在表格或区域中按行查找内容。...首先读取 Excel 文档 vlookup.xlsx 并获取活跃工作表;其次在单元格 B7 中写入公式 =VLOOKUP(A7,A1:B5,2,0);最后对 Excel 文档进行保存。...在公式 VLOOKUP(A7,A1:B5,2,0) 中,第一个参数 A7 是要查找的值;第二个参数 A1:B5 为要在其中查找值的区域;第三个参数 2 为查找值所在列的列号;第四个参数 0 为查找匹配项...单元格格式的设置 我们还可以使用 openpyxl 提供的方法对 Excel 文档的单元格格式进行设置。
标签:Excel技巧,保护工作表 有时候,我们想保护工作表中的公式,不让用户能够随便修改,但是又不想限制用户编辑除公式之外的数据。...此时,不能够简单的使用“保护工作表”命令,稍微需要添加一点技巧来实现。 按以下步骤操作: 步骤1:按Ctrl+A组合键,选择整个工作表单元格。...步骤2:单击鼠标右键,从快捷菜单中选择“设置单元格格式”命令。在弹出的“设置单元格格式”对话框中选择“保护”选项卡,取消“锁定”前复选框中的勾选,如下图1所示。...步骤4:单击“定位条件”对话框中的“公式”单选按钮,如下图3所示,单击“确定”。 图3 此时,Excel选择工作表中所有包含公式的单元格。...图4 步骤6:单击功能区“审阅”选项卡中的“保护工作表”命令。 此时,如果想修改工作表中包含公式的单元格,则会弹出如下图5所示的警告框。
在Excel中,名称是一个非常好的功能,不仅能够简化公式,而且让公式的可读性更好。本文介绍一个小技巧,可以让定义的名称快速应用到公式中。对于使用单元格引用的公式,这是一个非常好应用名称的方法。...在公式中快速应用名称的过程示例如下图1所示。 ? 图1 在工作表中,已定义单元格E2的名称为“价格”,E3的名称为“成本”,E4的名称为“税率”。...单元格E5中原来的公式为: =(E2-E3)*(1-E4) 应用名称后的公式为: =(价格-成本)*(1-税率) 操作步骤: 1.选择包含公式的单元格。...2.单击功能区“公式”选项卡“定义的名称”组中的“定义名称——应用名称”命令。 3.在“应用名称”对话框中选择要应用的名称,单击“确定”按钮。...注意:对于先创建名称,后编写公式的情形,如果在编写公式时选择单元格,那么会自动应用名称。 欢迎在下面留言,完善本文内容,让更多的人学到更完美的知识。
一列数据,我们想知道这列中单元格内容最长的文本长度值。通常,可能会在旁边的列中使用LEN函数求得每个单元格文本的长度,然后再使用MAX函数获得最大长度值,如下图1所示。 ?...实际上,我们可以使用一个数组公式来实现。数组公式: =MAX(LEN(B3:B12)) 如下图2所示。 ?...图2 公式中: LEN(B3:B12) 将生成由单元格区域中每个单元格内容长度值组成的数组: {7;6;4;5;12;6;3;6;1;3} 传递给MAX函数可得到最大长度值:12
领取专属 10元无门槛券
手把手带您无忧上云