python學習筆記(四):pandas基礎

来源:https://www.cnblogs.com/xihehe/archive/2018/05/11/9026860.html
-Advertisement-
Play Games

pandas 基礎 serise 0 4 1 7 2 5 3 3 dtype: int64 array([ 4, 7, 5, 3], dtype=int64) RangeIndex(start=0, stop=4, step=1) 1 7 3 3 dtype: int64 1 7 2 5 dtype ...


pandas 基礎

serise

import pandas as pd
from pandas import Series, DataFrame
obj = Series([4, -7, 5, 3])
obj
0    4
1   -7
2    5
3    3
dtype: int64
obj.values
array([ 4, -7,  5,  3], dtype=int64)
obj.index
RangeIndex(start=0, stop=4, step=1)
obj[[1,3]]
# 跳著選取數據
1   -7
3    3
dtype: int64
obj[1:3]
1   -7
2    5
dtype: int64
pd.isnull(obj)
0    False
1    False
2    False
3    False
dtype: bool
  • reindex可以用來插值
obj.reindex(range(5), method = 'ffill')
0    4
1   -7
2    5
3    3
4    3
dtype: int64
  • 標簽切片是閉區間的

dataframe

data = {'state': ['asd','qwe','sdf','ert'],
       'year': [2000, 2001, 2002, 2003],
       'pop': [1.5,1.7,3.6,2.4]}
data = DataFrame(data)
data
pop state year
0 1.5 asd 2000
1 1.7 qwe 2001
2 3.6 sdf 2002
3 2.4 ert 2003
data.year
# 比r里提取列要方便點
0    2000
1    2001
2    2002
3    2003
Name: year, dtype: int64
data['debt'] = range(4)
data
pop state year debt
0 1.5 asd 2000 0
1 1.7 qwe 2001 1
2 3.6 sdf 2002 2
3 2.4 ert 2003 3
  • index是不能修改的
a = data.index
a[1] = 6
---------------------------------------------------------------------------

TypeError                                 Traceback (most recent call last)

<ipython-input-9-57677294f950> in <module>()
      1 a = data.index
----> 2 a[1] = 6


F:\Anaconda\lib\site-packages\pandas\core\indexes\base.py in __setitem__(self, key, value)
   1668 
   1669     def __setitem__(self, key, value):
-> 1670         raise TypeError("Index does not support mutable operations")
   1671 
   1672     def __getitem__(self, key):


TypeError: Index does not support mutable operations
data.columns
Index(['pop', 'state', 'year', 'debt'], dtype='object')
  • .ix標簽索引功能,輸入行和列
  • 不加.ix只能選取其中的某列或某行,不能列與行同時選取
data[:3]
pop state year debt
0 1.5 asd 2000 0
1 1.7 qwe 2001 1
2 3.6 sdf 2002 2
data.ix[:,:3]
pop state year
0 1.5 asd 2000
1 1.7 qwe 2001
2 3.6 sdf 2002
3 2.4 ert 2003
  • 刪除某列用drop,axis = 0表示行,1表示列
  • 刪除後原數據不變
data.drop(0,axis=0)
pop state year debt
1 1.7 qwe 2001 1
2 3.6 sdf 2002 2
3 2.4 ert 2003 3
data.drop('year', axis=1)
pop state debt
0 1.5 asd 0
1 1.7 qwe 1
2 3.6 sdf 2
3 2.4 ert 3
data
pop state year debt
0 1.5 asd 2000 0
1 1.7 qwe 2001 1
2 3.6 sdf 2002 2
3 2.4 ert 2003 3
import numpy as np
df = DataFrame(np.arange(9).reshape(3, 3))
df
0 1 2
0 0 1 2
1 3 4 5
2 6 7 8
  • applymap()可以對dataframe每一個元素運用函數
  • apply()可以對每一維數組運用函數
df.applymap(lambda x: '%.2f' % x)
0 1 2
0 0.00 1.00 2.00
1 3.00 4.00 5.00
2 6.00 7.00 8.00
data.sort_values(by='pop')
# 對某一列排序
pop state year debt
0 1.5 asd 2000 0
1 1.7 qwe 2001 1
3 2.4 ert 2003 3
2 3.6 sdf 2002 2
data.describe()
pop year debt
count 4.000000 4.000000 4.000000
mean 2.300000 2001.500000 1.500000
std 0.948683 1.290994 1.290994
min 1.500000 2000.000000 0.000000
25% 1.650000 2000.750000 0.750000
50% 2.050000 2001.500000 1.500000
75% 2.700000 2002.250000 2.250000
max 3.600000 2003.000000 3.000000
df.isin([1])
0 1 2
0 False True False
1 False False False
2 False False False
  • None、NaN會被當作NA處理
  • df.shape不加括弧相當於dim()
df.shape
(3, 3)
  • dropna刪除缺失值
df.ix[:1, :1] = None
df
0 1 2
0 NaN NaN 2
1 NaN NaN 5
2 6.0 7.0 8
  • 填充缺失值可以調用字典,不同行添加不同值
df.fillna({0:11, 1:22})
0 1 2
0 11.0 22.0 2
1 11.0 22.0 5
2 6.0 7.0 8
df
0 1 2
0 NaN NaN 2
1 NaN NaN 5
2 6.0 7.0 8
df.fillna({0:11, 1:22}, inplace=True)
0 1 2
0 11.0 22.0 2
1 11.0 22.0 5
2 6.0 7.0 8
df
0 1 2
0 11.0 22.0 2
1 11.0 22.0 5
2 6.0 7.0 8
  • inplace修改對象不產生副本

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 於2018-5-10日晚 網路流傳黑客DDOS攻擊了QQ伺服器,導致大家聊天發送內容時出現感嘆號。我們都知道一般情況下出現感嘆號都是你的網路不穩定,或者...別人已經刪除你了。然而昨晚很奇怪,發出的內容出現感嘆號,但是內容的確是真的發出去了,也就是說別人接受到了你的內容。 看看當時的情況: 我非常同 ...
  • <resultMap id="recMap" type="com.winter.entity.work.RecruitEntity"> <id column="rec_id" property="recId"/> <result column="rec_name" property="recName ...
  • 1 學習計劃 1、Linux部署 n 安裝jdk n 安裝tomcat n 安裝MySQL n 將項目發佈到tomcat 2、擴展資料 2 Linux部署 2.1 安裝jdk 第一步:獲取Linux系統中jdk安裝包 第二步:使用secureCRT客戶端工具連到伺服器 第三步:使用命令創建一個目錄, ...
  • 一、字典的概念 字典跟列表很像,特別是表達方式通過花括弧代替方括弧。當然,字典的元素通過左邊部分為鍵右邊部分為值通過冒號來分割。 二、字典的創建 {'jack': 4098, 'sape': 4139, 'yellow': 8466}{'jack': 4098, 'sape': 4139, 'yel ...
  • 【程式1】 題目:古典問題:有一對兔子,從出生後第3個月起每個月都生一對兔子,小兔子長到第三個月後每個月又生一對兔子,假如兔子都不死,問每個月的兔子總數為多少? 1.程式分析:兔子的規律為數列1,1,2,3,5,8,13,21.... 具體分析如下: 分析:從第一個兔子開始,第1個月1只兔子,由於“ ...
  • 在研究學術之餘,來複習一下java的SpringMVC框架,最近也沒什麼項目,所以也有一段時間沒有看這個框架了,都有點陌生了,現在每天都在看論文,研究方案,做實驗,在論文看不下去的時候就來學習一下SPringMVC也是不錯的選擇,哈哈哈!!!!!! 1. springmvc框架 1.1 什麼是spr ...
  • 一.protobuf 安裝 protobuf版本:2.6.1 下載地址:https://github.com/google/protobuf/archive/v2.6.1.zip 解壓之後進入目錄 修改autogen.sh 將autogen.sh內的上述內容修改為 然後執行autogen.sh ./ ...
  • DTL 變數 標簽 過濾器 1. 語法:{ { 變數|過濾器 }},例如{ { name|lower }},表示將變數name的值變為小寫輸出 2. 使用管道符號 (|)來應用過濾器 3. 通過使用過濾器來改變變數的計算結果 4. 可以在if標簽中使用過濾器結合運算符 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...