打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
厉害了,在Pandas中用SQL来查询数据,效率超高

作者:俊欣

来源:关于数据分析与可视化

今天我们继续来讲一下PandasSQL之间的联用,我们其实也可以在Pandas当中使用SQL语句来筛选数据,通过Pandasql模块来实现该想法,首先我们来安装一下该模块

pip install pandasql

要是你目前正在使用jupyter notebook,也可以这么来下载

!pip install pandasql

导入数据

我们首先导入数据

import pandas as pdfrom pandasql import sqldfdf = pd.read_csv('Dummy_Sales_Data_v1.csv', sep=',')df.head()

output

我们先对导入的数据集做一个初步的探索性分析,

df.info()

output

<class 'pandas.core.frame.DataFrame'>RangeIndex: 9999 entries, 0 to 9998Data columns (total 12 columns): # Column Non-Null Count Dtype --- ------ -------------- ----- 0 OrderID 9999 non-null int64 1 Quantity 9999 non-null int64 2 UnitPrice(USD) 9999 non-null int64 3 Status 9999 non-null object 4 OrderDate 9999 non-null object 5 Product_Category 9963 non-null object 6 Sales_Manager 9999 non-null object 7 Shipping_Cost(USD) 9999 non-null int64 8 Delivery_Time(Days) 9948 non-null float64 9 Shipping_Address 9999 non-null object 10 Product_Code 9999 non-null object 11 OrderCode 9999 non-null int64 dtypes: float64(1), int64(5), object(6)memory usage: 937.5+ KB

再开始进一步的数据筛选之前,我们再对数据集的列名做一个转换,代码如下

df.rename(columns={'Shipping_Cost(USD)':'ShippingCost_USD',                   'UnitPrice(USD)':'UnitPrice_USD',                   'Delivery_Time(Days)':'Delivery_Time_Days'},          inplace=True)df.info()

output

<class 'pandas.core.frame.DataFrame'>RangeIndex: 9999 entries, 0 to 9998Data columns (total 12 columns): # Column Non-Null Count Dtype --- ------ -------------- ----- 0 OrderID 9999 non-null int64 1 Quantity 9999 non-null int64 2 UnitPrice_USD 9999 non-null int64 3 Status 9999 non-null object 4 OrderDate 9999 non-null object 5 Product_Category 9963 non-null object 6 Sales_Manager 9999 non-null object 7 ShippingCost_USD 9999 non-null int64 8 Delivery_Time_Days 9948 non-null float64 9 Shipping_Address 9999 non-null object 10 Product_Code 9999 non-null object 11 OrderCode 9999 non-null int64 dtypes: float64(1), int64(5), object(6)memory usage: 937.5+ KB

用SQL筛选出若干列来

我们先尝试筛选出OrderIDQuantitySales_ManagerStatus等若干列数据,用SQL语句应该是这么来写的

SELECT OrderID, Quantity, Sales_Manager, \Status, Shipping_Address, ShippingCost_USD \FROM df

Pandas模块联用的时候就这么来写

query = 'SELECT OrderID, Quantity, Sales_Manager,\Status, Shipping_Address, ShippingCost_USD \FROM df'df_orders = sqldf(query)df_orders.head()

output

SQL中带WHERE条件筛选

我们在SQL语句当中添加指定的条件进而来筛选数据,代码如下

query = 'SELECT * \        FROM df_orders \        WHERE Shipping_Address = 'Kenya''        df_kenya = sqldf(query)df_kenya.head()

output

而要是条件不止一个,则用AND来连接各个条件,代码如下

query = 'SELECT * \ FROM df_orders \ WHERE Shipping_Address = 'Kenya' \ AND Quantity < 40 \ AND Status IN ('Shipped', 'Delivered')'df_kenya = sqldf(query)df_kenya.head()

output

分组

同理我们可以调用SQL当中的GROUP BY来对筛选出来的数据进行分组,代码如下

query = 'SELECT Shipping_Address, \        COUNT(OrderID) AS Orders \        FROM df_orders \        GROUP BY Shipping_Address'df_group = sqldf(query)df_group.head(10)

output

排序

而排序在SQL当中则是用ORDER BY,代码如下

query = 'SELECT Shipping_Address, \ COUNT(OrderID) AS Orders \ FROM df_orders \ GROUP BY Shipping_Address \ ORDER BY Orders'df_group = sqldf(query)df_group.head(10)

output

数据合并

我们先创建一个数据集,用于后面两个数据集之间的合并,代码如下

query = 'SELECT OrderID,\        Quantity, \        Product_Code, \        Product_Category, \        UnitPrice_USD \        FROM df'df_products = sqldf(query)df_products.head()

output

我们这里采用的两个数据集之间的交集,因此是INNER JOIN,代码如下

query = 'SELECT T1.OrderID, \ T1.Shipping_Address, \ T2.Product_Category \ FROM df_orders T1\ INNER JOIN df_products T2\ ON T1.OrderID = T2.OrderID'df_combined = sqldf(query)df_combined.head()

output

与LIMIT之间的联用

SQL当中的LIMIT是用于限制查询结果返回的数量的,我们想看查询结果的前10个,代码如下

query = 'SELECT OrderID, Quantity, Sales_Manager, \ Status, Shipping_Address, \ShippingCost_USD FROM df LIMIT 10'df_orders_limit = sqldf(query)df_orders_limit

output

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
整理了10个经典的Pandas数据查询案例
机器学习开放课程(一):使用Pandas探索数据分析
pandas 将“字符类型的日期列”转化成“时间戳索引(DatetimeIndex)”
居然翻了 pandas.read_csv 的船
用Python抓取了2500多份数据类岗位的招聘需求,终于发现了未来最吃香的岗位竟然是这个!
如何将 DataFrame 列类型从对象类型转换为日期时间?
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服