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

Python實現(xiàn)指定范圍內(nèi)篩選并剔除Excel表格中的數(shù)據(jù)

 更新時間:2023年06月09日 08:21:56   作者:瘋狂學習GIS  
這篇文章主要為大家詳細介紹了Python如何實現(xiàn)在指定范圍內(nèi)篩選并剔除Excel表格中的數(shù)據(jù),文中的示例代碼講解詳細,感興趣的可以了解一下

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

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

其中,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)

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

1.導入必要的庫:導入了pandas庫,用于數(shù)據(jù)處理和操作。

2.定義文件路徑:定義了原始文件路徑original_file和結(jié)果文件路徑result_file。

3.讀取原始數(shù)據(jù):使用pd.read_csv()函數(shù)讀取原始文件數(shù)據(jù),并將其存儲在DataFrame對象df中。

4.數(shù)據(jù)篩選:對DataFrame對象df進行多個條件的篩選操作,使用了邏輯運算符&和比較運算符進行條件組合。例如,其中的第一行df["inf"] >= -0.2 和 df["inf"] <= 18就表示篩選出"inf"列的值在-0.2到18之間的數(shù)據(jù);第二行df["NDVI"] >= -1 和 df["NDVI"] <= 1則表示篩選出"NDVI"列的值在-1到1之間的數(shù)據(jù),以此類推。

5.保存結(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實現(xiàn)指定范圍內(nèi)篩選并剔除Excel表格中的數(shù)據(jù)的文章就介紹到這了,更多相關(guān)Python篩選Excel數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解python爬蟲系列之初識爬蟲

    詳解python爬蟲系列之初識爬蟲

    這篇文章主要介紹了python爬蟲系列之初識爬蟲,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • 解決PyCharm同目錄下導入模塊會報錯的問題

    解決PyCharm同目錄下導入模塊會報錯的問題

    今天小編就為大家分享一篇解決PyCharm同目錄下導入模塊會報錯的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • Tensorflow實現(xiàn)在訓練好的模型上進行測試

    Tensorflow實現(xiàn)在訓練好的模型上進行測試

    今天小編就為大家分享一篇Tensorflow實現(xiàn)在訓練好的模型上進行測試,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Python命令行定時任務(wù)自動化工作流程

    Python命令行定時任務(wù)自動化工作流程

    本文介紹如何使用Python編寫定時任務(wù),以自動執(zhí)行命令行任務(wù)。您將學習如何安排定期的任務(wù),處理任務(wù)結(jié)果,以及如何使用Python自動化工作流程,從而提高工作效率。無需手動執(zhí)行重復任務(wù),Python幫您搞定
    2023-04-04
  • python數(shù)據(jù)可視化之初探?Seaborn

    python數(shù)據(jù)可視化之初探?Seaborn

    Seaborn?是一個基于?Matplotlib?的?Python?數(shù)據(jù)可視化庫,它提供了更高級別的接口,使得創(chuàng)建美觀的統(tǒng)計圖形變得非常簡單,在這篇文章中,我們將討論?Seaborn?的基礎(chǔ)使用方法,包括如何創(chuàng)建各種常見的統(tǒng)計圖形
    2023-07-07
  • Python3中urlencode和urldecode的用法詳解

    Python3中urlencode和urldecode的用法詳解

    今天小編就為大家分享一篇Python3中urlencode和urldecode的用法詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • 解讀keras中的正則化(regularization)問題

    解讀keras中的正則化(regularization)問題

    這篇文章主要介紹了解讀keras中的正則化(regularization)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Python 進程操作之進程間通過隊列共享數(shù)據(jù),隊列Queue簡單示例

    Python 進程操作之進程間通過隊列共享數(shù)據(jù),隊列Queue簡單示例

    這篇文章主要介紹了Python 進程操作之進程間通過隊列共享數(shù)據(jù),隊列Queue,結(jié)合實例形式分析了Python進程數(shù)據(jù)共享、隊列數(shù)據(jù)處理相關(guān)操作技巧,需要的朋友可以參考下
    2019-10-10
  • Python調(diào)用Java數(shù)據(jù)接口實現(xiàn)CRUD操作的詳細指南

    Python調(diào)用Java數(shù)據(jù)接口實現(xiàn)CRUD操作的詳細指南

    Python和Java作為兩種流行的編程語言,在企業(yè)級應(yīng)用中常常需要實現(xiàn)跨語言的數(shù)據(jù)交互,下面我們就來看看如何在Django Python項目中調(diào)用Java數(shù)據(jù)接口實現(xiàn)CRUD操作吧
    2025-04-04
  • python下os模塊強大的重命名方法renames詳解

    python下os模塊強大的重命名方法renames詳解

    這篇文章主要介紹了python下os模塊強大的重命名方法renames詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03

最新評論