婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 使用Python制作一個(gè)數(shù)據(jù)預(yù)處理小工具(多種操作一鍵完成)

使用Python制作一個(gè)數(shù)據(jù)預(yù)處理小工具(多種操作一鍵完成)

熱門(mén)標(biāo)簽:如何申請(qǐng)400電話代理 甘肅高頻外呼系統(tǒng) 地圖標(biāo)注可以遠(yuǎn)程操作嗎 杭州房產(chǎn)地圖標(biāo)注 天津塘沽區(qū)地圖標(biāo)注 智能電話機(jī)器人調(diào)研 江門(mén)智能電話機(jī)器人 400電話在線如何申請(qǐng) 滴滴地圖標(biāo)注公司

在我們平常使用Python進(jìn)行數(shù)據(jù)處理與分析時(shí),在import完一大堆庫(kù)之后,就是對(duì)數(shù)據(jù)進(jìn)行預(yù)覽,查看數(shù)據(jù)是否出現(xiàn)了缺失值、重復(fù)值等異常情況,并進(jìn)行處理。

本文將結(jié)合GUI工具PySimpleGUI,來(lái)講解如何制作一款屬于自己的數(shù)據(jù)預(yù)處理小工具,讓這個(gè)過(guò)程也能夠自動(dòng)化!最終效果如下

本文將分為三部分講解:

  • 制作GUI界面
  • 數(shù)據(jù)處理講解
  • 打包與測(cè)試

主要涉及將涉及以下模塊:

  • PySimpleGUI
  • pandas
  • matplotlib

一、GUI界面制作

思路

老規(guī)矩,先講思路再上代碼,首先還是說(shuō)一下,使用PySimpleGUI還是那四個(gè)流程

引入模塊==>創(chuàng)建元素并填充layout==> 創(chuàng)建窗體 ==>創(chuàng)建事件循環(huán)

從元素看,從圖中可以知道我們需要的元素有使用說(shuō)明這個(gè)菜單欄、看上去是凹下去的數(shù)據(jù)預(yù)處理框、框內(nèi)的3個(gè)單選項(xiàng)值、讀取文件路徑的3個(gè)元素(固定文本、輸入文本、瀏覽按鈕)、"查看、處理、關(guān)閉"三個(gè)按鈕。

從總體看,整個(gè)窗體中我們需要所有的元素呈現(xiàn)正中間的分布狀態(tài)。其中菜單欄在窗體邊緣靠左分布。采用行銜接式的總分布。

從事件上看,我們需要在使用說(shuō)明菜單中加上使用者需要的注意事項(xiàng)。而文件讀取位置我們?cè)O(shè)置我們常用的2種數(shù)據(jù)存儲(chǔ)格式(“.xlsx”,“.xls”)的Excel格式。

讀取后,我們?cè)跀?shù)據(jù)預(yù)處理框架選擇一種處理。接著,我們可以對(duì)每一種錯(cuò)誤進(jìn)行彈出框查看,查看完之后對(duì)數(shù)據(jù)做最終處理。

處理的過(guò)程需要將處理好的數(shù)據(jù)覆蓋原來(lái)的數(shù)據(jù)文件。整個(gè)過(guò)程必須是持續(xù)不間斷的。這里說(shuō)個(gè)tips:每次數(shù)據(jù)分析之前最好做一個(gè)備份,防止分析過(guò)程中失敗但是又找不到原來(lái)數(shù)據(jù)文件的尷尬。

代碼

看望思路后是不是有種蠢蠢欲動(dòng)的感覺(jué)?!我們來(lái)實(shí)現(xiàn)一波,先看完整代碼,后面詳細(xì)拆解

import PySimpleGUI as sg 
import pandas as pd 
import matplotlib 
matplotlib.use("TkAgg") 
sg.ChangeLookAndFeel('GreenTan') 
menu_def = [['使用說(shuō)明', ['注意']]] 
layout = [ 
  [sg.Menu(menu_def, tearoff=True)], 
  [sg.Frame(layout=[ 
  [sg.Radio('重復(fù)值處理', "RADIO1",size=(15,1),key="dup"), sg.Radio('缺失值處理', "RADIO1",size=(15,1),key="mis"), sg.Radio('異常值處理', "RADIO1",default=True,key="war")]], title='數(shù)據(jù)預(yù)處理',title_color='green',title_location='n',relief=sg.RELIEF_SUNKEN, tooltip='選擇其中一種處理方式' )], 
  [sg.Text('文件位置', size=(8, 1), auto_size_text=False, justification='right'), 
   sg.InputText(enable_events=True,key="lujing"), sg.Button('瀏覽',key = 'getf')], 
  [sg.Button('查看',key = 'look'),sg.Submit('處理',key = 'handle'), sg.Cancel('關(guān)閉')]] 
 
window = sg.Window('特征工程', layout, default_element_size=(40, 1), grab_anywhere=False) 
while True: 
  event, values = window.read() 
  if event == 'getf': 
    text = sg.popup_get_file('請(qǐng)點(diǎn)擊瀏覽鍵或自行填入文件絕對(duì)路徑',title = '獲取件',file_types = (("Excel Files", "*.xlsx"),("Excel Files", "*.xls"),)) 
    sg.popup('提示', '是否確認(rèn)選擇文件---', text) 
    window['lujing'].update(text)  
  if event == "look": 
 ''' 
 用戶點(diǎn)擊查看按鈕促發(fā)的事件 
 ''' 
  if event == "handle": 
 ''' 
 用戶點(diǎn)擊處理按鈕促發(fā)的事件 
 '''    
  if event == "Cancel" or event == sg.WIN_CLOSED: 
    break   
  if event == "注意": 
 ''' 
 注意事項(xiàng)編寫(xiě) 
 ''' 

代碼解釋

其實(shí)有了思路后,你就會(huì)發(fā)現(xiàn)似乎一切都變得簡(jiǎn)單了。接下來(lái)講解相關(guān)參數(shù)的作用。

首先是matplotlib.use("TkAgg"):使用matplotlib模塊并且調(diào)用這個(gè)函數(shù)的目的是在我們進(jìn)行查看異常值處理(箱型圖展示)所用到,是改變圖像顯示的方式:TkAgg(一個(gè)交互式后臺(tái))。

所謂交互式后臺(tái)就是你可以對(duì)圖像進(jìn)行任意操作,區(qū)域放大縮小、值查看等功能。

之所以調(diào)用這個(gè)函數(shù)首先是因?yàn)槲覀兪褂玫氖荊UI是要有那種交互的感覺(jué)的,其次是如果數(shù)據(jù)量較大時(shí),箱型圖會(huì)很小,這樣子可以利于查看。

其次sg.ChangeLookAndFeel('GreenTan'):改變窗體顏色。

那么menu_def就是菜單欄,使用【“”,【“”】】這種格式來(lái)定義主菜單欄和子菜單欄。tearoff這個(gè)函數(shù)是加一條可愛(ài)的虛線間隔每個(gè)字段。

sg.Frame():這個(gè)和sg.columns()元素的用法是一樣的,主要是用來(lái)多個(gè)子元素的,我們這里設(shè)置了relief參數(shù)來(lái)讓整個(gè)框架在觀感上顯得凹形。tooltip參數(shù)是你鼠標(biāo)移動(dòng)框架的位置出現(xiàn)的小提示框。

title_location參數(shù)的用法非常有趣,是標(biāo)題字符串的位置設(shè)置,有(n,s,e,w,se等),你很快會(huì)發(fā)現(xiàn)這個(gè)位置和其他元素布局位置設(shè)置不一樣,他是以地理位置坐標(biāo)做子參數(shù)的。

sg.Radio:?jiǎn)芜x選項(xiàng)框,要將所有的單選選項(xiàng)框的子參數(shù)group_id都設(shè)成一樣的,這樣你才能三個(gè)選項(xiàng)中選一個(gè),這里我們以"RADIO1"為group_id。

sg.Button():整個(gè)GUI中我們使用了4個(gè)按鈕,其中有一個(gè)專(zhuān)有的按鈕Cancel。

sg.popup():比較初級(jí)的彈出框,顯示提示類(lèi)的關(guān)鍵信息所用到。

sg.popup_get_file():這是一個(gè)高級(jí)的彈出框元素,是從帶有文本輸入字段和瀏覽按鈕的彈出窗口,以便用戶選擇文件。效果如下

二、數(shù)據(jù)預(yù)處理

GUI部分搞定后,接著我們講解數(shù)據(jù)處理部分,主要是針對(duì)重復(fù)值、缺失值和異常值。

數(shù)據(jù)準(zhǔn)備

我們這里用到的是2020年10月28日A股的行情。數(shù)據(jù)部分展示:

我們可以看到這里面有重復(fù)的行、有缺失值的地方。

重復(fù)值處理

對(duì)于二維列表DataFrame來(lái)講使用Pandas模塊是最方便最象征辦公簡(jiǎn)潔化的模塊

import pandas as pd 
df = df.read_excel('文件絕對(duì)路徑') 
imfor = df[df.duplicated()] 
imfor = str(imfor) 

首先調(diào)用Pandas模塊并讀取文件路徑,這里我們采取絕對(duì)路徑而不采取相對(duì)路徑的原因是我們之后打包的GUI是不依靠文件的靠Python自帶的環(huán)境,所以相對(duì)路徑讀取是無(wú)法識(shí)別的。

df[df.duplicated()]這個(gè)Pandas內(nèi)的函數(shù)是以二維列表形式來(lái)打印重復(fù)值對(duì)應(yīng)的行。這里把df變量變?yōu)閟tr字符串形式是因?yàn)槲覀冊(cè)诤髞?lái)GUI中使用彈出窗口的元素時(shí)要以字符串形式加載。

最終處理重復(fù)值的方法如下:

df = df.drop_duplicates(inplace = True) 

代碼只有一行,卻能做到將整個(gè)數(shù)據(jù)表中的重復(fù)值都刪除,說(shuō)明Pandas函數(shù)的強(qiáng)大。

至于為什么用inplace = True,是因?yàn)閯h除函數(shù)不并不能改變?cè)砀窠Y(jié)構(gòu),所以需要將新表覆蓋原來(lái)的表格。

缺失值處理

先看代碼,其實(shí)在之前有關(guān)缺失值處理我在一年前就寫(xiě)過(guò)相關(guān)文章點(diǎn)擊查看

import pandas as pd 
df = df.read_excel('文件絕對(duì)路徑') 
#df.isnull() 
imfor1 = df.isnull().sum() 
#df.isnull().any() 
imfor1 = str(imfor1) 

對(duì)于有缺失值的的數(shù)據(jù)表來(lái)說(shuō),df.isnull()或者df.isna()來(lái)查看空值。這個(gè)函數(shù)的作用時(shí)判斷是否為空值,若是為空值則賦予True,否則賦予False。

這里我們使用df.isnull().sum()來(lái)統(tǒng)計(jì)每一列字段的缺失值數(shù)量。如果數(shù)據(jù)量大的話,還可以使用df.isnull().any()來(lái)查看只有缺失值的行。

解決方法,處理缺失值的方法有很多種,取均值、取中位數(shù)、刪除、取下方的值等。我們這里用取上方值的方法來(lái)填補(bǔ)。

df = df.fillna(method='pad') 

異常值處理

所謂異常值,就是在一個(gè)數(shù)字字段里出現(xiàn)一個(gè)或多個(gè)不合群得數(shù)字。舉個(gè)例子,在一列都為個(gè)位數(shù)得數(shù)字列中出現(xiàn)了一個(gè)百位數(shù)的數(shù)字,這個(gè)百位數(shù)就是異常值。

用Python檢測(cè)異常值有兩種:箱線圖圖觀察和標(biāo)準(zhǔn)差觀察。這里我們選則箱體圖觀察。

箱線圖是用于顯示所選數(shù)據(jù)分散情況的統(tǒng)計(jì)圖,通過(guò)設(shè)定標(biāo)準(zhǔn),將大于或小于箱體圖上下線的數(shù)值表示為異常點(diǎn)。

如圖,下四分分位數(shù)指的是樣本中有百分之25的數(shù)據(jù)小于這個(gè)數(shù),記為。上四分分位數(shù)指的是樣本中有百分之25大于這個(gè)數(shù),記為。上四分位數(shù)和下四分位數(shù)的差值的1.5倍加上上四分位數(shù)就是上邊緣,反之為下邊緣。

在Pandas中可以調(diào)用.boxplot()函數(shù)來(lái)畫(huà)箱型圖
import pandas as pd 
df.boxplot()

打包與效果展示

在寫(xiě)完全部代碼之后,我們可以使用pyinstaller進(jìn)行打包。

假定你的程序命名為yuchuli.py,在cmd窗口輸入即可完成打包。

pyinstaller -F yuchuli.py 

打包后,exe在Python文件所在文件夾的dist文件夾中。我們啟動(dòng)來(lái)看下效果

可以看到,我們需要的數(shù)據(jù)預(yù)處理的三個(gè)功能:重復(fù)值、缺失值、異常值都能按照指定方式進(jìn)行處理!

當(dāng)然你可以在本文提供的方法上,自己進(jìn)行修改,來(lái)定制一款屬于你自己平時(shí)習(xí)慣的數(shù)據(jù)預(yù)處理小軟件!

到此這篇關(guān)于使用Python制作一個(gè)數(shù)據(jù)預(yù)處理小工具(多種操作一鍵完成)的文章就介紹到這了,更多相關(guān)Python數(shù)據(jù)預(yù)處理小工具內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 快速一鍵生成Python爬蟲(chóng)請(qǐng)求頭
  • 如何打包Python Web項(xiàng)目實(shí)現(xiàn)免安裝一鍵啟動(dòng)的方法
  • 利用Python代碼實(shí)現(xiàn)一鍵摳背景功能
  • Ubuntu18.04 一鍵升級(jí)Python所有第三方包 及安裝python包的方法
  • Python一鍵安裝全部依賴包的方法
  • Python一鍵查找iOS項(xiàng)目中未使用的圖片、音頻、視頻資源
  • Python 一鍵獲取百度網(wǎng)盤(pán)提取碼的方法
  • Python 一鍵制作微信好友圖片墻的方法
  • Python字典循環(huán)添加一鍵多值的用法實(shí)例
  • Python趣味爬蟲(chóng)之用Python實(shí)現(xiàn)智慧校園一鍵評(píng)教

標(biāo)簽:漢中 廊坊 德宏 東莞 長(zhǎng)春 重慶 臨汾 河池

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用Python制作一個(gè)數(shù)據(jù)預(yù)處理小工具(多種操作一鍵完成)》,本文關(guān)鍵詞  使用,Python,制作,一個(gè),數(shù)據(jù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用Python制作一個(gè)數(shù)據(jù)預(yù)處理小工具(多種操作一鍵完成)》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于使用Python制作一個(gè)數(shù)據(jù)預(yù)處理小工具(多種操作一鍵完成)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    久久久精品一品道一区| 日韩美女在线视频| 日本亚洲视频在线| 亚洲免费资源在线播放| 免费成人在线观看视频| 国产黑丝在线一区二区三区| 精品剧情在线观看| 欧美精品xxxxbbbb| 亚洲欧美偷拍三级| 亚洲免费av在线| 婷婷开心激情综合| 91网站在线观看视频| 青青草国产精品97视觉盛宴| 欧美日韩一级二级| 欧美一卡2卡3卡4卡| 久久免费视频色| 亚洲同性同志一二三专区| 久久综合丝袜日本网| 亚洲国产日韩一区二区| 成人美女在线观看| 精品国产免费一区二区三区四区 | 久久福利视频一区二区| 91免费观看视频| 国产午夜精品福利| 欧美影院一区二区三区| 91在线观看视频| 国产美女精品人人做人人爽| 国产丝袜在线精品| 91欧美一区二区| 亚洲午夜视频在线| 欧美大肚乱孕交hd孕妇| 免费成人美女在线观看| 久久精品欧美一区二区三区不卡 | 日韩成人免费看| 国产亚洲va综合人人澡精品| 日本亚洲一区二区| 丰满少妇久久久久久久| 亚洲精品老司机| 久久精品国产秦先生| 国产精品情趣视频| 在线不卡免费欧美| 粉嫩13p一区二区三区| 亚洲自拍欧美精品| 97超碰欧美中文字幕| 婷婷中文字幕一区三区| 久久精品亚洲精品国产欧美| 在线一区二区视频| 久久99精品久久久久久动态图 | 欧美videofree性高清杂交| 成人动漫一区二区| 色婷婷精品久久二区二区蜜臀av| 一区二区三区高清| 国产三区在线成人av| 欧美视频精品在线观看| 福利电影一区二区| 国产乱码精品一区二区三区忘忧草 | 欧美一区二区视频免费观看| 9i在线看片成人免费| 国产精品一级在线| 蜜臀av国产精品久久久久| 亚洲欧美日本韩国| 国产色一区二区| 国产精品女主播av| 国产99精品国产| 日韩毛片视频在线看| 日韩精品一二区| 欧美在线观看一区| 成人免费精品视频| 国产一区二区三区电影在线观看 | 色婷婷精品久久二区二区蜜臂av | 成人高清av在线| 国产成人av影院| 经典三级在线一区| 久久激情综合网| 美女一区二区在线观看| 午夜精品爽啪视频| 五月激情六月综合| 亚洲国产日韩在线一区模特| 中文字幕中文字幕一区| 久久精品亚洲精品国产欧美| 久久婷婷国产综合国色天香| 欧美精品一区二区三区蜜臀| 精品国产百合女同互慰| 久久在线观看免费| 中文在线免费一区三区高中清不卡| 精品国产乱码久久久久久图片| 日韩欧美一级二级| 日韩欧美一级在线播放| 久久一日本道色综合| 欧美韩国日本一区| 亚洲视频 欧洲视频| 亚洲电影中文字幕在线观看| 香蕉久久一区二区不卡无毒影院| 首页国产欧美日韩丝袜| 久久99日本精品| 老色鬼精品视频在线观看播放| 老司机免费视频一区二区| 国产精品99久久久久久有的能看| 成人app软件下载大全免费| 成人毛片在线观看| 欧美又粗又大又爽| 欧美一区二区视频在线观看2022| 久久免费美女视频| 午夜精品福利一区二区三区蜜桃| 老汉av免费一区二区三区| av在线播放不卡| 欧美精品aⅴ在线视频| 中文字幕+乱码+中文字幕一区| 91捆绑美女网站| 精品国产自在久精品国产| 亚洲欧美日韩在线| 亚洲自拍偷拍九九九| 久久不见久久见免费视频7| 不卡免费追剧大全电视剧网站| 欧美亚洲高清一区| 欧美三级日韩在线| 国产日韩欧美综合一区| 亚洲成人动漫av| 成人黄色软件下载| 日韩视频不卡中文| 亚洲自拍偷拍av| 粉嫩嫩av羞羞动漫久久久| 欧美日韩成人在线| 国产精品乱码人人做人人爱| 麻豆国产精品视频| 99国产精品久久久久久久久久久| 91精品国产综合久久精品app| 亚洲日本韩国一区| 国产老女人精品毛片久久| 91 com成人网| 国产亚洲精品免费| 久久www免费人成看片高清| 欧美在线观看视频一区二区 | 午夜精品在线看| 在线国产电影不卡| 亚洲人成伊人成综合网小说| 久久99精品国产麻豆婷婷洗澡| 色吊一区二区三区| 亚洲视频精选在线| 91亚洲国产成人精品一区二三| 久久久精品免费免费| 国内一区二区在线| 欧美一区二区三区视频免费| 亚洲一区二区三区四区五区中文| 色哟哟国产精品免费观看| 中文字幕视频一区| 成人黄色小视频| 国产精品每日更新在线播放网址 | 成人精品免费网站| 国产亚洲精品bt天堂精选| 看电视剧不卡顿的网站| 欧美一级精品在线| 免费成人美女在线观看| 精品成人一区二区三区| 国产精品亚洲专一区二区三区| 日韩免费观看高清完整版 | 日韩中文字幕91| 欧美午夜一区二区三区| 亚洲一区视频在线| 欧美三级中文字幕在线观看| 一区二区三区精品在线| 欧美美女网站色| 天天综合网天天综合色| 精品少妇一区二区三区免费观看 | 日本不卡123| 国产日产精品1区| 一本在线高清不卡dvd| 亚洲与欧洲av电影| 欧美日韩国产123区| 视频一区中文字幕| 精品欧美一区二区三区精品久久| 国产精品亚洲第一| 亚洲精品日韩专区silk| 欧美视频在线播放| 久久丁香综合五月国产三级网站| 中文字幕不卡在线播放| 欧美日韩第一区日日骚| 粉嫩蜜臀av国产精品网站| 亚洲欧洲日韩综合一区二区| 91精品国产综合久久香蕉的特点| 香蕉成人伊视频在线观看| 精品国产一区a| 99亚偷拍自图区亚洲| 免费观看在线色综合| 亚洲视频免费在线| 日韩一级片在线播放| 99国产精品久| 中文一区二区在线观看| 欧美日韩另类一区| 丁香啪啪综合成人亚洲小说 | 精品制服美女丁香| 亚洲精品国产精华液| 欧美日韩美女一区二区| 久久69国产一区二区蜜臀| 依依成人综合视频| 欧美日本在线看| 国内一区二区在线| 久久日一线二线三线suv| 欧美电影一区二区三区| 日本va欧美va瓶|