subset:用来指定特定的列,根据指定的列对数据框去重。默认值为None,即DataFrame中一行元素全部相同时才去除。...导入数据处理的库 os.chdir('F:/微信公众号/Python/26.基于多列组合删除数据框中的重复值') #把路径改为数据存放的路径 name = pd.read_csv('name.csv...从结果知,参数为默认值时,是在原数据的copy上删除数据,保留重复数据第一条并返回新数据框。 感兴趣的可以打印name数据框,删重操作不影响name的值。...结果和按照某一列去重(参数为默认值)是一样的。 如果想保留原始数据框直接用默认值即可,如果想直接在原始数据框删重可设置参数inplace=True。...但是对于两列中元素顺序相反的数据框去重,drop_duplicates函数无能为力。 如需处理这种类型的数据去重问题,参见本公众号中的文章【Python】基于多列组合删除数据框中的重复值。 -end-
最近公司在做关联图谱的项目,想挖掘团伙犯罪。在准备关系数据时需要根据两列组合删除数据框中的重复值,两列中元素的顺序可能是相反的。...二、基于两列删除数据框中的重复值 1 加载数据 # coding: utf-8 import os #导入设置路径的库 import pandas as pd #导入数据处理的库...import numpy as np #导入数据处理的库 os.chdir('F:/微信公众号/Python/26.基于多列组合删除数据框中的重复值') #把路径改为数据存放的路径 df =...从上图可以看出用set替换frozense会报不可哈希的错误。 三、把代码推广到多列 解决多列组合删除数据框中重复值的问题,只要把代码中取两列的代码变成多列即可。...numpy as np #导入数据处理的库 os.chdir('F:/微信公众号/Python/26.基于多列组合删除数据框中的重复值') #把路径改为数据存放的路径 name = pd.read_csv
学习Excel技术,关注微信公众号: excelperfect 这里的应用场景如下: “在工作表Sheet1中存储着数据,现在想要在该工作表的第O列至第T列中搜索指定的数据,如果发现,则将该数据所在行复制到工作表...用户在一个对话框中输入要搜索的数据值,然后自动将满足前面条件的所有行复制到工作表Sheet2中。” 首先,使用用户窗体设计输入对话框,如下图1所示。 ?...("O2:T"& lngRow) '查找的数据文本值 '由用户在文本框中输入 FindWhat = "*" &Me.txtSearch.Text & "*..." '调用FindAll函数查找数据值 '存储满足条件的所有单元格 Set rngFoundCells =FindAll(SearchRange:=rngSearch...上述两段代码的图片版如下: ? ?
要减小计算时间,考虑使用辅助列、布尔逻辑构造和有效的函数。 5.这里没有考虑使用VBA解决方案,有时使用它们是自动执行数据提取的好方法。 为何提取数据的公式如此复杂?...对于垂直表,从多列中提取数据的查找公式不会很难;查找公式难于在多行中使用。如果需要使用公式提取记录,那么有两个基本的方法: 1.基于辅助列使用标准的查找函数。...辅助列包含提供顺序号的公式,只要公式找到了满足条件的记录。这些顺序号解决了重复值问题,因为对于每条匹配的记录都有唯一的标识号。辅助列作为查找列,供查找函数查找并提取数据。 2.基于全数据集的数组公式。...注意,SUM函数将逻辑值转换成1或0,并且忽略文本值。 ? 图3:最终的辅助列公式使用SUM函数将AND函数的逻辑值与上方单元格中的值相加 单元格H6是一个辅助单元格。...对于本示例,构造辅助列的公式: =SUM(ISNUMBER(MATCH(D10,B3:B4,0)),A9) 或: =SUM(OR(D10=B3,D10=B4),N9) 示例:使用辅助列,AND和OR条件
因此,你可以把步骤100分配一个运输条件类型,计数1;另一个分配给步骤100,计数2;另一个分配给步骤100,计数3。 3、CTYP: 就是条件类型,这是计算方案的基础。...为小计定义范围。例如,如果你要累积从步骤10到50的所有条件类型,应该分别在“从”“到”种输入10和50。 2). 定义计算的基础。...计算方案使用“统计”增加一个统计值,这步的值不会改变方案中的其它值。这可以用于标识物料的成本价格。 8、打印: 该打印标志符确定分配给某一步骤的哪一个描述和相关值会输出到单据。...9、小计: 如果相同的字段用来存储不同的条件金额,系统将对单项数额求总和。这些条件金额或小计可以作为进一步计算的开始点。 10、需求: 用于给条件类型分配一个需求。...它确定在哪个环境下系统排斥对一个特定条件类型的存取。 11、计算类型: 指明系统将会在搜索条件类型的值时使用这个列代表的公式替代标准条件计数。在计算比较复杂的税率时一般会用到它。
本文提供了一种方法,在给定一个或多个相同布局的工作表的情况下,可以创建另一个“主”工作表,该工作表仅由满足特定条件的所有工作表中的数据组成。并且,这里不使用VBA,仅使用公式。...图3 想要创建一个主工作表Master,其数据来源于上面三个工作表中列D中的值为“Y”的数据: ?...D2:D10"),"Y"))) 可以根据实际情况,修改工作表列表和数据范围(D2:D10)。...一个是1行3列,得到一个3行3列的数组,该数组由9个TRUE/FALSE值组成: 0+({TRUE,FALSE,FALSE;TRUE,TRUE,FALSE;TRUE,TRUE,TRUE}) 转换为1/0...实际上,该技术的核心为:通过生成动态汇总小计数量的数组,该小计数量由来自每个工作表中符合条件(即在列D中的值为“Y”)的行数组成,然后将公式所在单元格相对行数与该数组相比较,以便有效地确定公式所在行中要指定的工作表
标签:VBA,AdvancedFilter方法 在处理大型数据集时,很可能需要查找并获取唯一值,特别是唯一字符串。...在VBA中,AdvancedFilter方法是处理这种情形的非常强大的一个工具。该方法可以保留原数据,采用基于工作表的条件,可以找到唯一值。下面,将详细介绍如何获取并将唯一值放置在单独的地方。...AdvancedFilter方法可以对多个列进行操作,如果只想筛选数据的子集,则可以限制其行范围。 可以跨列筛选唯一值。...如果输出区域太小,无法包含所有结果,VBA将溢出该区域。这意味着无法限制输出,因此要选择一个没有值或可以覆盖原有值的列。...另一个需要注意的是,如果要筛选的数据中有两列具有相同的标题,xlFilterCopy可能会将具有该名称的第一列复制两次到目标列(CopyToRange)。
3、输入数据: 关于作图的数据组织:这里需要三列数据,一列省份名称、一列指标值,一列颜色填充值(需要使用函数自动获取)。 ? 4、定义组距 ? 5、定义颜色填充范围 ?...将F9:G13单元格区域选中并定义名称为color_table ? 使用concatenate函数制作分段值范围。 将D9-D13区域的五个单元格分别命名为color1~color5。...然后将提前准备好的地图填充色复制进D9-D13单元格中。 7、在C4列中匹配B列指标值的颜色范围。(使用vlookup函数) ?...C" & i).Value).Interior.Color '对各省的图形使用其颜色栏的值作为名称所指向的单元格的颜色填充 Next i Application.ScreenUpdating...选中D9:E13区域,点击照相机功能,然后在数据地图区域释放。 ? ? ? ? 还有一点需要提示一下,这种内涵VBA宏代码的文件需另存为xlsm格式才能保留宏功能,否则就会前功尽弃。
返回 仅返回小计,不返回可被引用的具体值 C. 注意事项 只有在SUMMARIZE函数中使用。 如果分组依据有多列,而RollUp未汇总全部列,则汇总未选择列。(可以看案例加深理解) D....因为未选择全部列,所以返回的是未选择列的汇总也就是学校的小计。...解释: 先汇总姓名,学校的值;然后在小计姓名的值;最后返回姓名小计的汇总。 6. ROLLUPADDISSUBTOTAL A....返回 不返回值,仅标记是否小计 C. 注意事项 只在ADDMISSINGITEMS内使用。 D. 作用 将汇总组合添加的列配对,返回一个逻辑值。 E. 案例 ?...解释: 添加判断一列去判断是否汇总小计,返回逻辑值。同时因为addmissingitems的原因把无成绩的这个也显示出来了。当然无度量的也就不存在判断不判断了,所以判断这里为空。
VBA对象可以是工作表(在Worksheet.Cells属性的情形)或可以是单元格区域(Range.Cells属性的情形)。 行号和列号是行和列的编号,通常使用数字。...Cells属性只能(通常)用于返回1个单元格的范围,这是区分Cells与Range属性的主要特征之一。 实际上,有一种方法可以使用Cells属性来引用更大的单元格范围。...如果使用的数字大于相关区域内的单元格数量,VBA将继续计数,就好像该范围比实际范围更高(一直延伸到底部)。换句话说:Cells属性返回的Range对象不必位于原始/源单元格区域内。...“偏移行”是要偏移基准区域的行数,该值可以是正值(向下偏移)或负值(向上偏移)。“偏移列”是要偏移区域的列数,如果为正值,则向右偏移,为负值将向左偏移。...偏移行和偏移列参数都基于“表达式”表示的Range对象左上角单元格偏移。 Offset属性的工作方式意味着它只能应用于Range对象。换句话说,没有Worksheet.Offset属性。
7.VBA程序报错,用调试三法宝,bug不存在的 8.VBA字符串介绍,这篇就够了 9.还自己写代码?...其主要用来控制表格「列」方向的循环; 第3层的IF分支结构,其主要用对指定条件进行判断。...3)程序执行For循环结构 image.png 程序读取「For j = 2 To 7」表明程序进入了第2层的「列循环」,换句话就是:j的取值在2到7之间,每循环一次j的值就增加1 ,直到j=7时整个...看到这里,可能大家有些疑问了,为什么变量i要限制它的取值范围?...image.png 大家心中肯定早就拥有了自己的答案:之所以将变量j的值限定在2-7之间,是因为我们需要判断的数据区域主要分布在B列-G列,其对应的cells数字值就是2-7。
IIf函数评估条件,如果为True,则返回一个值;如果为False,则返回另一个值。 9.如何确保Do... Loop语句中的语句至少执行一次? 仅当条件置于循环末尾时,才能保证语句至少执行一次。...17.VBA可以识别通用格式的日期,例如2020/11/11。在VBA代码中,如何表明该值是日期? 通过将其括在#字符中。 18.哪个VBA函数用于为日期添加间隔? DateAdd函数。...19.哪两个函数用于搜索文本(在另一个字符串中查找一个字符串)? InStr函数和InStrRev函数。 20.如何转换字符串,以使每个单词的首字母大写,而所有其他字母小写?...Excel公式技巧64:为重复值构造包含唯一值的辅助列 Excel小技巧67:列出工作表中所有定义的名称 完美Excel社群本周内容 本周完美Excel社群内容更新不是很多,仍然是《Excel编程周末速成班...》的后续内容: 第9课:处理文本 第10课:使用Ranges和Selections 第11课:处理列(Columns),行(Rows)和单元格(Cells) 下周继续努力,争取推出更多有用的内容。
4 -> 基于范围的for循环(C++11) 4.1 -> 范围for的语法 在C++98中要遍历一个数组通常用的方法为: #include using namespace std...,由程序员来说明循环的范围是多余的,有时候还会容易犯错误。...因此C++11中引入了基于范围的for循环。for循环后的括号由冒号“ :”分为两部分:第一部分是范围内用于迭代的变量,第二部分则表示被迭代的范围。...4.2 -> 范围for的使用条件 for循环迭代的范围必须是确定的 对于数组而言,就是数组中的第一个元素和最后一个元素的范围; 对于类而言,应该提供begin和end方法,begin和end就是for...循环迭代的范围。
标签:VBA,AdvancedFilter方法 本文探讨如何使用AdvancedFilter基于多个条件进行筛选,而不仅仅是一列数据。...我们无须在VBA代码中硬编码条件,我们可以构建一个新表,其标题与数据区域中的标题相匹配,然后,将筛选需求添加到此表中。第I列和第J列显示了新表,如下图2所示。...输出区域 唯一的强制参数Action有两个可能的值:XlFilterInPlace和XlFilterCopy。...这可以是另一个工作表,也可以是同一工作表上的另一个位置。 此方法还提供了对输出的更多控制,因为可以选择显示哪些字段。...如果不执行此操作,将出现“运行时错误’1004’:提取范围有一个缺少或无效的字段名”错误。
传统报表的实现方式大多基于 Table 控件,虽然可实现多个分组功能,但在报表显示方面有限制,只能呈现上下级的分组,而现代的复杂报表的需求,通常是左右级嵌套,有时甚至要求相同内容的单元格合并,使用 Table...控件,有太多的局限,有了矩表控件,通过简单的拖拽就能轻松实现多层分组报表,不管有多少个分组和分组小计都能简单解决。...“=【月】”字段的动态列,该列包含“=【周】”和按周小计。...添加合计 添加【生产方式】合计:添加成功之后,需要自行合并单元格,调整Value值: image.png image.png 添加总合计: image.png 添加“【周】”合计 image.png 添加总合计...调整样式 到这里,报表的整体结构都已创建完成了,需要做的就是调整报表样式。 image.png 运行效果 image.png 9.
、支持分栏功能、支持分版功能、支持动态合并格等等;下面就让我们一起来看一下具体的功能吧。...一、查询 1.控件类型 查询控件类型包括:输入框、下拉单选、下拉多选、 范围查询、模糊查询、下拉树、自定义下拉树;丰富了日期查询,可按年、按月查询;并且可设置默认值。...:调用key即可 3.MongoDB MongoDB调用方法:在报表SQL中配置满足标准的MongoDB Sql语法 三、分组小计 1.横向:compute用法 compute可实现横向列加减乘除包括带括号...()的优先计算。...2.纵向小计 纵向小计包含:求和、最大值、最小值、平均值、计数 四、钻取 图表钻取、条件钻取联动 报表及图表支持钻取及联动,也可根据条件钻取联动。
合并操作与联接相似,因为它们都是将两个表合并起来形成另一个表的方法。然而,它们的合并方法有本质上的不同,结果表的形状如下所示。 注:A和B分别代表两个数据源表。 ? ...嵌套查询是指将一个查询块嵌套在另一个查询块的WHERE子句或HAVING短语的条件中的查询。嵌套查询中上层的查询块称为外侧查询或父查询,下层查询块称为内层查询或子查询。...使用IS NULL查询空值 使用EXISTS关键字 使用ORDER BY排序 使用GROUP BY分组 使用HAVING对分组结果过滤 使用COMPUTE子句对查询结果小计 使用COMPUTE...BY子句分组小计 使用UNION合并查询结果集 8)使用聚合函数统计汇总 使用SUM()求列的和 使用AVG()求列平均值 使用MAX()求列最大值 使用MIN()求列最小值 使用COUNT...7、规则、默认和完整性约束 规则是对存储的数据表的列或用户定义数据类型中的值的约束,规则与其作用的表或用户定义数据类型是相互独立的,也就是说,对表或用户定义数据类型的任何操作与对其设置的规则不存在影响
关系型数据库很多,后文主要基于 MySQL 8.0.30 来讲解,偶尔会插入 PostgreSQL 14.1 ,没有特殊说明的情况下,都是基于 MySQL 8.0.30 MySQL 建表 tbl_ware...BY + 应用程序汇总 先通过数据库层面的 GROUP BY 得到小计,类似如下 然后通过程序代码对 商品类别 的小计进行一个合计 我敢断定,这种方式肯定是大家用的最多的方式,因为我就是这么用的...不过, Null 看着着实不爽,关键是坑还多:神奇的 SQL 之温柔的陷阱 → 三值逻辑 与 NULL ! ...BY 的 合计行 来理解 正是因为 合计行 的 ware_category 列的键值不明确,所以会默认使用 NULL 前面的案例只有一个聚合列,如果再加一列 registration_date...registration_date 归类的 小计 加上 GROUP BY ROLLUP(ware_category) 的结果,一共 9 + 4 = 13 条记录 如果聚合列有 3 列,大家还能明白每一行记录的含义吗
VBA允许用户以多种不同的方式引用单元格区域。 什么是Range对象 Range对象代表工作表中的单元格区域,这意味着可以使用Range对象来引用: 单个单元格 一行或一列单元格。...然而,这些并不是引用Range对象的唯一方法,还有一些更高级的方法,例如使用Application.Union方法,这里没有介绍。 基于上下文和特定的需要,确定引用Range对象的最佳方法。...引用Range对象以及对象限定符介绍 为了能够正确使用范围对象,必须了解如何使用Range对象引用的两个主要部分: 1.对象限定符。这是创建对象引用的一般规则。...这意味着可以应用Range.Range属性,用于引用与另一个区域相关的区域。下面将举例说明这种引用是如何工作的。...在尝试将值赋给合并的单元格时,应特别小心。通常,只能通过将值赋给区域的左上角单元格(上例中的单元格A1)来执行此操作。否则,ExcelVBA(通常)不会:进行赋值;和返回错误。
默认从Excel中复制的数据,(如果是复制到Word这类支持表格的软件,会复制表格过去,这个时候还可以进一步转换为文本),列与列之间是使用Tab连接,上一行与下一行是使用换行符连接。...如果列之间的连接符Tab和行之间的连接符换行符可以自定义就好了,那么,我们来实现这么一个复制的功能: ?...> 1 Then '选择的单元格范围的行数 iRows = rng.Rows.Count '选择的单元格范围的列数...Next '将列单元格的Text连接起来,并存放到arrStr中 arrStr(iRow) = VBA.Join...Set objData = CreateObject("new:{1C3B4210-F441-11CE-B9EA-00AA006B1A69}") With objData
领取专属 10元无门槛券
手把手带您无忧上云