python?pandas?query的使用方法
前言:
Pandas 中應(yīng)用 query 函數(shù)來(lái)進(jìn)行數(shù)據(jù)篩選。
query 函數(shù)的一般用法如下:
df.query('expression')
常用方法:
#!/usr/bin/python import pandas as pd import numpy as np data = { ?'brand':['Python',' C ',' C++ ','C#','Java'], ?'A':[10,2,5,20,16], ?'B':[4,6,8,12,10], ?'C':[8,12,18,8,2], ?'D':[6,18,14,6,12], ?'till years':[4,1,1,30,30] ?} df = pd.DataFrame(data=data) print("df數(shù)據(jù)打印:\n", df, '\n') print('查找數(shù)據(jù):\n', df.query('brand == "Python"'), '\n') print('查找數(shù)據(jù):\n', df[df['brand'] == "Python"], '\n')
可以使用df.query('brand == "Python"')進(jìn)行查找,也可以使用df[df['brand'] == "Python"]這種方式進(jìn)行查找。
out:
df數(shù)據(jù)打印:
brand A B C D till years
0 Python 10 4 8 6 4
1 C 2 6 12 18 1
2 C++ 5 8 18 14 1
3 C# 20 12 8 6 30
4 Java 16 10 2 12 30
查找數(shù)據(jù):
brand A B C D till years
0 Python 10 4 8 6 4
查找數(shù)據(jù):
brand A B C D till years
0 Python 10 4 8 6 4
通過(guò)數(shù)學(xué)表達(dá)式來(lái)篩選:
除了直接通過(guò)等于某個(gè)值來(lái)篩選, query 函數(shù)還支持通過(guò)數(shù)學(xué)表達(dá)式來(lái)進(jìn)行數(shù)據(jù)篩選,包括 > 、 < 、 + 、 - 、 * 、 / 等。
print('查找數(shù)據(jù):\n', df.query('A > 15'), '\n')
out:
查找數(shù)據(jù):
brand A B C D till years
3 C# 20 12 8 6 30
4 Java 16 10 2 12 30
通過(guò)變量篩選:
在程序比較長(zhǎng)的時(shí)候,經(jīng)常會(huì)使用變量來(lái)作為篩選條件, query 函數(shù)在使用變量作為判斷標(biāo)準(zhǔn)時(shí),通過(guò)在變量前面添加 @ 符號(hào)來(lái)實(shí)現(xiàn),
示例如下:
name = 'Java' print('查找數(shù)據(jù):\n', df.query('brand == @name'), '\n')
out:
查找數(shù)據(jù):
brand A B C D till years
4 Java 16 10 2 12 30
通過(guò)列表數(shù)據(jù)篩選:
當(dāng)需要在某列中篩選多個(gè)符合要求的值的時(shí)候,可以通過(guò)列表( list )來(lái)實(shí)現(xiàn),示例如下:
name = ['Python', 'Java'] print('查找數(shù)據(jù):\n', df.query('brand in @name'), '\n')
out:
查找數(shù)據(jù):
brand A B C D till years
0 Python 10 4 8 6 4
4 Java 16 10 2 12 30
多條件篩選:
- 兩者都需要滿足的并列條件使用符號(hào) & , 或單詞 and
- 只需要滿足其中之一的條件使用符號(hào) | , 或單詞 or
name = ['Python', 'Java'] print('查找數(shù)據(jù):\n', df.query('brand in @name & A > 15'), '\n')
out:
查找數(shù)據(jù):
brand A B C D till years
4 Java 16 10 2 12 30
列名稱中有空格的情況,使用``進(jìn)行處理:
使用引號(hào)處理的話,會(huì)報(bào)錯(cuò)。
print('查找數(shù)據(jù):\n', df.query('`till years` > 10'), '\n')
out:
查找數(shù)據(jù):
brand A B C D till years
3 C# 20 12 8 6 30
4 Java 16 10 2 12 30
篩選后選取數(shù)據(jù)列:
name = ['brand', 'A', 'B', 'till years'] print('查找數(shù)據(jù):\n', df.query('`till years` > 10')[name], '\n')
out:
查找數(shù)據(jù):
brand A B till years
3 C# 20 12 30
4 Java 16 10 30
總結(jié):
當(dāng)用到多條件篩選時(shí),使用query就會(huì)顯得簡(jiǎn)潔的多:
print(df[(df['brand'] == 'Python') & (df['A'] == 10) & (df['B'] == 4)]) print(df.query('brand == "Python" & A == 10 & B == 4'))
到此這篇關(guān)于python pandas query的使用方法的文章就介紹到這了,更多相關(guān)python pandas query 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python Pandas pandas.read_sql_query函數(shù)實(shí)例用法分析
- python中pandas操作apply返回多列的實(shí)現(xiàn)
- python?pandas創(chuàng)建多層索引MultiIndex的6種方式
- Python+pandas編寫命令行腳本操作excel的tips詳情
- Python Pandas實(shí)現(xiàn)DataFrame合并的圖文教程
- Python的Django框架實(shí)現(xiàn)數(shù)據(jù)庫(kù)查詢(不返回QuerySet的方法)
- Python中類似于jquery的pyquery庫(kù)用法分析
- python實(shí)現(xiàn)合并多個(gè)list及合并多個(gè)django QuerySet的方法示例
相關(guān)文章
python3安裝OCR識(shí)別庫(kù)tesserocr過(guò)程圖解
這篇文章主要介紹了python3安裝OCR識(shí)別庫(kù)tesserocr過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04深入解析Python中的__builtins__內(nèi)建對(duì)象
__builtins__ 是內(nèi)建模塊__builtin__中的對(duì)象,使用Python中的內(nèi)建函數(shù)時(shí)會(huì)通過(guò)__builtins__引導(dǎo),這里我們就來(lái)深入解析Python中的__builtins__內(nèi)建對(duì)象,需要的朋友可以參考下2016-06-06PyQt5 QThread倒計(jì)時(shí)功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了PyQt5 QThread倒計(jì)時(shí)功能的實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04python實(shí)現(xiàn)跳表SkipList的示例代碼
這篇文章主要介紹了python實(shí)現(xiàn)跳表SkipList的示例代碼,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-07-07Python實(shí)現(xiàn)動(dòng)態(tài)給類和對(duì)象添加屬性和方法操作示例
這篇文章主要介紹了Python實(shí)現(xiàn)動(dòng)態(tài)給類和對(duì)象添加屬性和方法操作,涉及Python面向?qū)ο蟪绦蛟O(shè)計(jì)中類與對(duì)象屬性、方法的動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2020-02-02Django uwsgi Nginx 的生產(chǎn)環(huán)境部署詳解
這篇文章主要介紹了Django uwsgi Nginx 的生產(chǎn)環(huán)境部署詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-02-02Python flask與fastapi性能測(cè)試方法介紹
這篇文章主要介紹了Python flask與fastapi性能測(cè)試方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-12-12python導(dǎo)出requirements.txt的幾種方法以及環(huán)境配置詳細(xì)流程
這篇文章主要給大家介紹了關(guān)于python導(dǎo)出requirements.txt的幾種方法以及環(huán)境配置詳細(xì)流程,requirements.txt 文件是一個(gè)文本文件,用于列出你的Python項(xiàng)目所依賴的軟件包及其版本,需要的朋友可以參考下2023-11-11python+tkinter實(shí)現(xiàn)一個(gè)簡(jiǎn)單的秒鐘
這篇文章主要為大家詳細(xì)介紹了Python如何利用tkinter實(shí)現(xiàn)一個(gè)簡(jiǎn)單的秒鐘,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴可以自己動(dòng)手嘗試一下2024-02-02