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

2020年入门数据分析选择Python还是SQL?七个常用操作对比!

二、查找 单条件查找 在SQL中,WHERE子句用于提取那些满足指定条件的记录,语法如下 SELECT column_name,column_name FROM table_name WHERE column_name...而在pandas中,按照条件进行查找则可以有多种形式,比如可以将含有True/False的Series对象传递给DataFrame,并返回所有带有True的行 ?...在pandas中也有类似的操作 ? 查找空值 在pandas检查空值是使用notna()和isna()方法完成的。...({'key': ['B', 'D', 'D', 'E'], ....: 'value': np.random.randn(4)}) 内连接 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行...全连接 全连接返回左表和右表中的所有行,无论是否匹配,但并不是所有的数据库都支持,比如mysql就不支持,在SQL中实现全连接可以使用FULL OUTER JOIN SELECT * FROM df1

3.6K31

一场pandas与SQL的巅峰大战

4.查询带有1个条件的数据 例如我们要查询uid为10003的所有记录。pandas需要使用布尔索引的方式,而SQL中需要使用where关键字。...多个条件满足其中一个的情况 与多个条件同时满足使用&相对应的,我们使用|符号表示一个条件满足的情况,而SQL中则用or关键字连接各个条件表示任意满足一个。...SQL操作时基本也是同样的逻辑,要指定主表,从表,连接方式和连接字段。此处我们使用user连接order并查询所有字段和所有记录。...在pandas中可能有一些细节需要注意,比如我们将聚合结果先赋值,然后重命名,并指定了inplace=True替换原来的命名,最后才进行排序,这样写虽然有点绕,但整体思路比较清晰。...删除操作可以细分为删除行的操作和删除列的操作。对于删除行操作,pandas的删除行可以转换为选择不符合条件进行操作。SQL需要使用delete关键字。

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

    高效的10个Pandas函数,你都用过吗?

    中最主要的数据分析库之一,它提供了非常多的函数、方法,可以高效地处理并分析数据。...:随机数发生器种子 axis:选择抽取数据的行还是列 axis=0:抽取行 axis=1:抽取列 比如要从df中随机抽取5行: sample1 = df.sample(n=5) sample1 从...Where Where用来根据条件替换行或列中的值。如果满足条件,保持原来的值,不满足条件则替换为其他值。默认替换为NaN,也可以指定特殊值。...Isin Isin也是一种过滤方法,用于查看某列中是否包含某个字符串,返回值为布尔Series,来表明每一行的情况。...如果未指定, 请使用未设置为id_vars的所有列 var_name [scalar]:指代用于”变量”列的名称。

    4.2K20

    一场pandas与SQL的巅峰大战

    4.查询带有1个条件的数据 例如我们要查询uid为10003的所有记录。pandas需要使用布尔索引的方式,而SQL中需要使用where关键字。...多个条件满足其中一个的情况 与多个条件同时满足使用&相对应的,我们使用|符号表示一个条件满足的情况,而SQL中则用or关键字连接各个条件表示任意满足一个。...SQL操作时基本也是同样的逻辑,要指定主表,从表,连接方式和连接字段。此处我们使用user连接order并查询所有字段和所有记录。...在pandas中可能有一些细节需要注意,比如我们将聚合结果先赋值,然后重命名,并指定了inplace=True替换原来的命名,最后才进行排序,这样写虽然有点绕,但整体思路比较清晰。...删除操作可以细分为删除行的操作和删除列的操作。对于删除行操作,pandas的删除行可以转换为选择不符合条件进行操作。SQL需要使用delete关键字。

    1.7K40

    一场pandas与SQL的巅峰大战

    4.查询带有1个条件的数据 例如我们要查询uid为10003的所有记录。pandas需要使用布尔索引的方式,而SQL中需要使用where关键字。...多个条件满足其中一个的情况 与多个条件同时满足使用&相对应的,我们使用|符号表示一个条件满足的情况,而SQL中则用or关键字连接各个条件表示任意满足一个。...SQL操作时基本也是同样的逻辑,要指定主表,从表,连接方式和连接字段。此处我们使用user连接order并查询所有字段和所有记录。...在pandas中可能有一些细节需要注意,比如我们将聚合结果先赋值,然后重命名,并指定了inplace=True替换原来的命名,最后才进行排序,这样写虽然有点绕,但整体思路比较清晰。...删除操作可以细分为删除行的操作和删除列的操作。对于删除行操作,pandas的删除行可以转换为选择不符合条件进行操作。SQL需要使用delete关键字。

    1.6K10

    几个高效Pandas函数

    Pandas是python中最主要的数据分析库之一,它提供了非常多的函数、方法,可以高效地处理并分析数据。让pandas如此受欢迎的原因是它简洁、灵活、功能强大的语法。...Where Where用来根据条件替换行或列中的值。如果满足条件,保持原来的值,不满足条件则替换为其他值。默认替换为NaN,也可以指定特殊值。...Isin Isin也是一种过滤方法,用于查看某列中是否包含某个字符串,返回值为布尔Series,来表明每一行的情况。...用法: DataFrame.memory_usage(index=True, deep=False) 参数解释: index:指定是否返回df中索引字节大小,默认为True,返回的第一行即是索引的内存使用情况...; deep:如果为True,则通过查询object类型进行系统级内存消耗来深入地检查数据,并将其包括在返回值中。

    1.6K60

    数据分析之Pandas合并操作总结

    这个verify_integrity就是为了保证只有在索引相同时才会进行操作的函数,而可以拿来检查函数列是否唯一。...join:这个函数也适用于行拼接,多用于many_to_one的情况,还可以应对多层keys的拼接。 例子的话可以看上面的讲解,也是比较详细的。...(a) 每个公司有多少员工满足如下条件:既出现第一张表,又出现在第二张表。...(b) 将所有不符合(a)中条件的行筛选出来,合并为一张新表,列名与原表一致。...(c) 现在需要编制所有80位员工的信息表,对于(b)中的员工要求不变,对于满足(a)条件员工,它们在某个指标的数值,取偏离它所属公司中满足(b)员工的均值数较小的哪一个,例如:P公司在两张表的交集为{

    4.8K31

    学习SQLite之路(二)

    = 检查两个操作数的值是否相等,如果相等则条件为真。 (a = b) 不为真。 != 检查两个操作数的值是否相等,如果不相等则条件为真。 (a != b) 为真。... 检查两个操作数的值是否相等,如果不相等则条件为真。 (a b) 为真。 > 检查左操作数的值是否大于右操作数的值,如果是则条件为真。 (a > b) 不为真。...检查左操作数的值是否小于右操作数的值,如果是则条件为真。 (a < b) 为真。 >= 检查左操作数的值是否大于等于右操作数的值,如果是则条件为真。 (a >= b) 不为真。...检查左操作数的值是否小于等于右操作数的值,如果是则条件为真。 (a <= b) 为真。 !检查左操作数的值是否不小于右操作数的值,如果是则条件为真。 (a !< b) 为假。 !...BETWEEN BETWEEN 运算符用于在给定最小值和最大值范围内的一系列值中搜索值。 EXISTS EXISTS 运算符用于在满足一定条件的指定表中搜索行的存在。

    2K70

    pandas使用技巧-分组统计数据

    Pandas分组统计 本文介绍的是pandas库中如何实现数据的分组统计: 不去重的分组统计,类似SQL中统计次数 去重的分组统计,类型SQL的统计用户数,需要去重 模拟数据1 本文案例的数据使用的是...检查数据是否重复 因为数据是随机生成的,我们需要检查是否有出现这种情况:name、subject、time、grade4个字段相同,但是score出现了两次,防止数据不规范。...写了一个循环来进行判断: # 写个循环判断是否有重复行的数据 for i in range(len(data)): for j in range(len(data)): # 当name、subject...模拟数据2 数据 import pandas as pd df = pd.DataFrame({ 'group': [1, 1, 2, 3, 3, 3, 4], 'param': ['...from_records方法 下面记录pandas中from_records方法的使用: 参数 DataFrame.from_records(data, index=None, exclude=None

    2.2K30

    Pandas高级数据处理:自定义函数

    优化算法:检查自定义函数中的算法是否可以优化。例如,减少不必要的计算步骤,或者采用更高效的算法来解决问题。三、常见报错及解决方法(一)KeyError1....报错原因当我们尝试访问DataFrame或Series中不存在的列名或索引时,就会触发KeyError。这可能是由于拼写错误、数据结构不一致等原因造成的。2. 解决方法检查列名或索引是否正确。...可以通过df.columns查看DataFrame的所有列名,确保在自定义函数中引用的列名准确无误。对于可能存在缺失的情况,在访问之前先进行判断。..., len(sorted_group) + 1) return sorted_group# 根据科目分组并计算排名df_ranked = df.groupby('subject').apply(calculate_rank...接着又定义了一个score_to_grade函数来根据成绩划分等级,并将其应用到每一行数据上。这样我们就实现了较为复杂的数据处理逻辑,满足了业务需求。

    10310

    Pandas部分应掌握的重要知识点

    ① 因为多数条件都会涉及列标签,因此都要使用loc索引器(而非iloc索引器); ② 因为通常是寻找满足条件的行,所以索引器内部需要在行的维度上表达查询条件。...()[['Q1','Q2']] #如果如果只有一列,则无需使用花式索引,如下所示: #team.groupby('team').mean()['Q1'] 2、找到满足条件的分组(过滤掉不满足条件的分组...该任务可以分两步进行: #(1)用filter函数得到满足所需条件的分组中的记录,它的结果是整个数据集的子集 flt_df=team.groupby('team').filter(lambda x: (...having子句) ② filter函数返回满足过滤条件的分组中的记录,而不是满足条件的分组 ③ 其参数必须是函数,本例中lambda函数的形参x代表每个分组 ④ 当组对象存在多列时,filter...的过滤条件要求显式的指定某一列 六、处理缺失值 1、Pandas中缺失值的表示 Pandas表示缺失值的一种方法是使用NaN(Not a Number),它是一个特殊的浮点数;另一种是使用Python中的

    4700

    Pandas库

    通过这些基础知识和资源,你可以逐步深入学习Pandas,从而在数据分析领域游刃有余。 Pandas库中Series和DataFrame的性能比较是什么?...在Pandas库中,Series和DataFrame是两种主要的数据结构,它们各自适用于不同的数据操作任务。我们可以对这两种数据结构的性能进行比较。...如何在Pandas中实现高效的数据清洗和预处理? 在Pandas中实现高效的数据清洗和预处理,可以通过以下步骤和方法来完成: 处理空值: 使用dropna()函数删除含有缺失值的行或列。...使用Z-Score等统计方法识别并移除异常值。 统一数据格式: 确保所有数据列具有相同的格式,例如统一日期格式、货币格式等。...例如,可以根据特定条件筛选出满足某些条件的数据段,并对这些数据段应用自定义函数进行处理。

    8410

    七步搞定一个综合案例,掌握pandas进阶用法!

    案例浅析 虽然在表述上有些绕,但其实需求还是比较明确的。仔细分析,从业务逻辑上,这里需要用到pandas的如下技巧。...为了验证结果,我们取出city='杭州',sub_cate='用品'的所有样本进行查看,这里用到了pandas多条件筛选数据操作。...这里需要对每组内按行进行遍历,用到了iterrows函数,并判断cum_pct与50%,group_rank与3的关系。我们自定义一个函数来实现。...上图第三列就是我们需要的目标group_rank值,注意先要把默认的名字改过来,并将此结果与原始数据做一个合并。在此基础上,就可以将每组内不超过目标group_rank值的行筛选出来。...6.分组拼接 在上一步筛选出了目标行,未达到最终目标,还需将每个分组内所有符合条件的产品名称拼接起来,并用逗号隔开。这里采用分组对字符串求和的方式来实现。

    2.7K40

    一场pandas与SQL的巅峰大战(二)

    pandas中实现这个问题可能比较麻烦,也可能有很多不同的写法。这里说一下我的思路和实现方式。...我定义了两个函数,第一个函数给原数据增加一列,标记我们的条件,第二个函数再增加一列,当满足条件时,给出对应的orderid,然后要对整个dataframe应用这两个函数。...为了减少干扰,我们将order数据重新读入,并设置了pandas的显示方式。 ? 可以看到,同一个uid对应的订单id已经显示在同一行了,订单id之间以逗号分隔。...我没有找到pandas实现这样数组形式比较好的方法,如果你知道,欢迎一起交流.另外,pandas在聚合时,如何去重,也是一个待解决的问题。...七 行转列 later view explode 行转列的操作在Hive SQL中有时会遇到,可以理解为将上一小节的结果还原为每个orderid显示一行的形式。

    2.3K20

    1000+倍!超强Python『向量化』数据处理提速攻略

    将整个Series作为参数传递到函数中,而不是对每一行。 但没有成功。if语句试图确定Series作为一个整体的真实性,而不是比较Series中的每个元素,所以这是错误的。...当条件满足且为True时,将返回第二个参数,否则返回第三个参数。 看下面的例子: numpy.where()它从我们的条件中创建一个布尔数组,并在条件为真或假时返回两个参数,它对每个元素都这样做。...根据经验,你需要为每个return语句设置n个条件,这样就可以将所有布尔数组打包到一个条件中,以返回一个选项。...代码如下: 如果添加了.values: 4 更复杂的 有时必须使用字符串,有条件地从字典中查找内容,比较日期,有时甚至需要比较其他行的值。我们来看看!...向量化所需要的所有函数都是在同一行上比较的值,这可以使用pandas.shift()实现! 确保你的数据正确排序,否则你的结果就没有意义! 很慢!

    6.8K41

    使用R或者Python编程语言完成Excel的基础操作

    熟悉界面:打开Excel并熟悉其界面,包括菜单栏、工具栏、功能区等。 掌握基本操作:学习如何插入、删除行/列,重命名工作表,以及基本的数据输入。...条件格式:学习如何使用条件格式来突出显示满足特定条件的单元格。 图表:学习如何根据数据创建图表,如柱状图、折线图、饼图等。 数据排序和筛选:掌握如何对数据进行排序和筛选,以查找和组织信息。...模板 使用模板:快速创建具有预定义格式和功能的表格。 高级筛选 自定义筛选条件:设置复杂的筛选条件,如“大于”、“小于”、“包含”等。 错误检查 追踪错误:找出公式中的错误来源。...错误检查:使用Excel的错误检查功能识别和修复常见错误。 函数库 使用Excel函数库:利用Excel提供的大量预定义函数进行复杂的数据处理。...[-2] > 10: # 假设 'Sales' 在倒数第二列 row[-2] = 10 查询数据 # 查询 'Sales' 大于5 的所有行 filtered_data = [row

    23810

    解读 Optimizing Queries Using Materialized Views:A Practical, Scalable Solution

    为提升匹配的命中率,需要进行谓词解释并利用表达式间的等价关系。例如,交换律是一个重要的等价关系,可适用于比较、加法、乘法和OR运算。可根据谓词条件函数中可适用的等价关系来设计不同复杂程度的匹配算法。...校验视图每个范围是否包含对应的查询范围,如果不是,则拒绝该视图 检查视图剩余谓词中的每个合取项是否与查询剩余谓词中的某个合取项匹配。...只需检查被引用等价类中的列是否至少包含一个是视图的输出列,然后将引用指向该视图列。...除此之外,视图还需满足上一节的验证条件。为满足初始假定查询与视图的表引用相同,从概念上将额外表 追加到查询中,并使用视图消除额外表时相同的外键连接方式,将额外表与查询原始表进行连接。...这是安全的,但也有一定的局限性,在实际中,仅要求保证查询中实际使用的行满足这一点即可,而无需所有行。 示例,假设视图由表 和表 通过 连接而成,其中 为 外键, 为 主键。

    15642

    30 个小例子帮你快速掌握Pandas

    = df.sample(frac=0.1) df_sample2.shape --- (1000,10) 5.缺失值检查 isna函数用于确定DataFrame中的缺失值。...df.isna().sum().sum() --- 0 9.根据条件选择行 在某些情况下,我们需要适合某些条件的观察值(即行)。例如,下面的代码将选择居住在法国并且已经流失的客户。...我们可以看到每组中观察值(行)的数量和平均流失率。 14.将不同的汇总函数应用于不同的组 我们不必对所有列都应用相同的函数。例如,我们可能希望查看每个国家/地区的平均余额和流失的客户总数。...19.where函数 它用于根据条件替换行或列中的值。默认替换值是NaN,但我们也可以指定要替换的值。 考虑上一步(df_new)中的DataFrame。...method参数指定如何处理具有相同值的行。first表示根据它们在数组(即列)中的顺序对其进行排名。 21.列中唯一值的数量 使用分类变量时,它很方便。我们可能需要检查唯一类别的数量。

    10.8K10
    领券