欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python按條件刪除Excel表格數(shù)據(jù)的方法(示例詳解)

 更新時間:2024年08月10日 09:08:25   作者:瘋狂學(xué)習GIS  
本文介紹基于Python語言,讀取Excel表格文件,基于我們給定的規(guī)則,對其中的數(shù)據(jù)加以篩選,將不在指定數(shù)據(jù)范圍內(nèi)的數(shù)據(jù)剔除,保留符合我們需要的數(shù)據(jù)的方法,感興趣的朋友跟隨小編一起看看吧

本文介紹基于Python語言,讀取Excel表格文件,基于我們給定的規(guī)則,對其中的數(shù)據(jù)加以篩選,將不在指定數(shù)據(jù)范圍內(nèi)的數(shù)據(jù)剔除,保留符合我們需要的數(shù)據(jù)的方法。

  首先,我們來明確一下本文的具體需求。現(xiàn)有一個Excel表格文件(在本文中我們就以.csv格式的文件為例),如下圖所示。

image

  其中,Excel表格文件具有大量的數(shù)據(jù),每一列表示某一種屬性,每一行表示某一個樣本;我們需要做的,就是對于其中的部分屬性加以數(shù)據(jù)篩選——例如,我們希望對上圖中第一列的數(shù)據(jù)進行篩選,將其中大于2或小于-1的部分選出來,并將每一個所選出的單元格對應(yīng)的直接刪除;同時,我們還希望對其他的屬性同樣加以篩選,不同屬性篩選的條件也各不相同,但都是需要將不符合條件的單元格所在的整行都刪除。最終,我們保留下來的數(shù)據(jù),就是符合我們需要的數(shù)據(jù),此時我們需要將其保存為一個新的Excel表格文件。

  明白了需求,我們即可開始代碼的撰寫;本文用到的具體代碼如下所示。

# -*- coding: utf-8 -*-
"""
Created on Wed Jun  7 15:40:50 2023
@author: fkxxgis
"""
import pandas as pd
original_file = "E:/01_Reflectivity/99_Model_Training/00_Data/02_Extract_Data/23_Train_model_NoH/Train_Model_1_NoH.csv"
result_file = "E:/01_Reflectivity/99_Model_Training/00_Data/02_Extract_Data/23_Train_model_NoH/Train_Model_1_NoH_New.csv"
df = pd.read_csv(original_file)
df = df[(df["inf"] >= -0.2) & (df["inf"] <= 18)]
df = df[(df["NDVI"] >= -1) & (df["NDVI"] <= 1)]
df = df[(df["inf_dif"] >= -0.2) & (df["inf_dif"] <= 18)]
df = df[(df["NDVI_dif"] >= -2) & (df["NDVI_dif"] <= 2)]
df = df[(df["soil"] >= 0)]
df = df[(df["inf_h"] >= -0.2) & (df["inf_h"] <= 18)]
df = df[(df["ndvi_h"] >= -1) & (df["ndvi_h"] <= 1)]
df = df[(df["inf_h_dif"] >= -0.2) & (df["inf_h_dif"] <= 18)]
df = df[(df["ndvi_h_dif"] >= -1) & (df["ndvi_h_dif"] <= 1)]
df.to_csv(result_file, index = False)

  下面是對上述代碼每個步驟的解釋:

  • 導(dǎo)入必要的庫:導(dǎo)入了pandas庫,用于數(shù)據(jù)處理和操作。
  • 定義文件路徑:定義了原始文件路徑original_file和結(jié)果文件路徑result_file。
  • 讀取原始數(shù)據(jù):使用pd.read_csv()函數(shù)讀取原始文件數(shù)據(jù),并將其存儲在DataFrame對象df中。
  • 數(shù)據(jù)篩選:對DataFrame對象df進行多個條件的篩選操作,使用了邏輯運算符&和比較運算符進行條件組合。例如,其中的第一行df["inf"] >= -0.2 和 df["inf"] <= 18就表示篩選出"inf"列的值在-0.218之間的數(shù)據(jù);第二行df["NDVI"] >= -1 和 df["NDVI"] <= 1則表示篩選出"NDVI"列的值在-11之間的數(shù)據(jù),以此類推。
  • 保存結(jié)果數(shù)據(jù):使用to_csv()函數(shù)將篩選后的DataFrame對象df保存為新的.csv文件,保存路徑為result_file,并設(shè)置index=False以避免保存索引列。

  當然,如果我們需要對多個屬性(也就是多個列)的數(shù)據(jù)加以篩選,除了上述代碼中的方法,我們還可以用如下所示的代碼,較之前述代碼會更方便一些。

result_df = result_df[(result_df["blue"] > 0) & (result_df["blue"] <= 1) &
                              (result_df["green"] > 0) & (result_df["green"] <= 1) &
                              (result_df["red"] > 0) & (result_df["red"] <= 1) &
                              (result_df["inf"] > 0) & (result_df["inf"] <= 1) &
                              (result_df["NDVI"] > -1) & (result_df["NDVI"] < 1) &
                              (result_df["inf_dif"] > -1) & (result_df["inf_dif"] < 1) &
                              (result_df["NDVI_dif"] > -2) & (result_df["NDVI_dif"] < 2) &
                              (result_df["soil"] >= 0) &
                              (result_df["NDVI_dif"] > -2) & (result_df["NDVI_dif"] < 2) &
                              (result_df["inf_h_dif"] > -1) & (result_df["inf_h_dif"] < 1) &
                              (result_df["ndvi_h_dif"] > -1) & (result_df["ndvi_h_dif"] < 1)]

  上述代碼可以直接對DataFrame對象加以一次性的篩選,不用每篩選一次就保存一次了。

  運行本文提及的代碼,我們即可在指定的結(jié)果文件夾下獲得數(shù)據(jù)篩選后的文件了。

到此這篇關(guān)于Python按條件刪除Excel表格數(shù)據(jù)的方法的文章就介紹到這了,更多相關(guān)Python 刪除Excel表格數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 用Python替換證件照背景顏色

    用Python替換證件照背景顏色

    大家好,本篇文章主要講的是用Python替換證件照背景顏色,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • python使用reportlab實現(xiàn)圖片轉(zhuǎn)換成pdf的方法

    python使用reportlab實現(xiàn)圖片轉(zhuǎn)換成pdf的方法

    這篇文章主要介紹了python使用reportlab實現(xiàn)圖片轉(zhuǎn)換成pdf的方法,涉及Python使用reportlab模塊操作圖片轉(zhuǎn)換的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • Python腳本實現(xiàn)自動發(fā)帶圖的微博

    Python腳本實現(xiàn)自動發(fā)帶圖的微博

    這篇文章主要介紹了Python腳本實現(xiàn)自動發(fā)帶圖的微博的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • Python的Django框架中設(shè)置日期和字段可選的方法

    Python的Django框架中設(shè)置日期和字段可選的方法

    這篇文章主要介紹了Python的Django框架中設(shè)置日期和字段可選的方法,是Django設(shè)置當中的基本操作,需要的朋友可以參考下
    2015-07-07
  • python中列表list切分的實現(xiàn)

    python中列表list切分的實現(xiàn)

    列表是Python中最常用的數(shù)據(jù)結(jié)構(gòu)之一,經(jīng)常需要對列表進行切分操作,本文主要介紹了python中列表list切分的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2025-03-03
  • python如何批量讀取.mat文件并保存成.npy

    python如何批量讀取.mat文件并保存成.npy

    這篇文章主要介紹了python如何批量讀取.mat文件并保存成.npy問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • python虛擬機之描述器實現(xiàn)原理與源碼分析

    python虛擬機之描述器實現(xiàn)原理與源碼分析

    在本篇文章當中主要給大家介紹描述器背后的實現(xiàn)原理,通過分析?cpython對應(yīng)的源代碼了解與描述器相關(guān)的字節(jié)碼的指令,我們就可以真正了解到描述器背后的原理,需要的朋友可以參考下
    2023-05-05
  • Python中String模塊示例詳解

    Python中String模塊示例詳解

    string模塊主要包含關(guān)于字符串的處理函數(shù),這篇文章主要介紹了Python中String模塊示例代碼,代碼簡單易懂,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • python 圖像處理畫一個正弦函數(shù)代碼實例

    python 圖像處理畫一個正弦函數(shù)代碼實例

    這篇文章主要介紹了python 圖像處理畫一個正弦函數(shù)代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友可以參考下
    2019-09-09
  • python?中?os.walk()?函數(shù)詳解

    python?中?os.walk()?函數(shù)詳解

    os.walk()是一種遍歷目錄數(shù)的函數(shù),它以一種深度優(yōu)先的策略(depth-first)訪問指定的目錄。這篇文章主要介紹了python?中?os.walk()?函數(shù),需要的朋友可以參考下
    2021-11-11

最新評論