精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Python教你用 Rows 快速操作csv文件

科技綠洲 ? 來源:Python實用寶典 ? 作者:Python實用寶典 ? 2023-10-21 10:18 ? 次閱讀

Rows 是一個專門用于操作表格的第三方Python模塊。

只要通過 Rows 讀取 csv 文件,她就能生成可以被計算的 Python 對象。

相比于 pandas 的 pd.read_csv, 我認為 Rows 的優勢在于其易于理解的計算語法和各種方便的導出和轉換語法。它能非常方便地提取pdf中的文字、將csv轉換為sqlite文件、合并csv等,還能對csv文件執行sql語法,還是比較強大的。

當然,它的影響力肯定沒有 Pandas 大,不過了解一下吧,技多不壓身。

1.準備

開始之前,你要確保Python和pip已經成功安裝在電腦上,如果沒有,可以訪問這篇文章:超詳細Python安裝指南 進行安裝。

**(可選1) **如果你用Python的目的是數據分析,可以直接安裝Anaconda:Python數據分析與挖掘好幫手—Anaconda,它內置了Python和pip.

**(可選2) **此外,推薦大家用VSCode編輯器,它有許多的優點:Python 編程的最好搭檔—VSCode 詳細指南

請選擇以下任一種方式輸入命令安裝依賴

  1. Windows 環境 打開 Cmd (開始-運行-CMD)。
  2. MacOS 環境 打開 Terminal (command+空格輸入Terminal)。
  3. 如果你用的是 VSCode編輯器 或 Pycharm,可以直接使用界面下方的Terminal.
pip install rows

2.基本使用

通過下面這個小示例,你就能知道Rows的基本使用方法。

假設我們有這樣的一個csv表格數據:

state,city,inhabitants,area
AC,Acrelandia,12538,1807.92
AC,Assis Brasil,6072,4974.18
AC,Brasiléia,21398,3916.5
AC,Bujari,8471,3034.87
AC,Capixaba,8798,1702.58
[...]
RJ,Angra dos Reis,169511,825.09
RJ,Aperibé,10213,94.64
RJ,Araruama,112008,638.02
RJ,Areal,11423,110.92
RJ,Arma??o dos Búzios,27560,70.28
[...]

如果我們想要找出 state 為 RJ 并且人口大于 500000 的城市,只需要這么做:

import rows

cities = rows.import_from_csv("data/brazilian-cities.csv")
rio_biggest_cities = [
    city for city in cities
    if city.state == "RJ" and city.inhabitants > 500000
]
for city in rio_biggest_cities:
    density = city.inhabitants / city.area
    print(f"{city.city} ({density:5.2f} ppl/km2)")

和 Pandas 很像,但是語法比 Pandas 簡單,整個模塊也比 Pandas 輕量。

如果你想要自己新建一個"表格", 你可以這么寫:

from collections import OrderedDict
from rows import fields, Table


country_fields = OrderedDict([
    ("name", fields.TextField),
    ("population", fields.IntegerField),
])

countries = Table(fields=country_fields)
countries.append({"name": "Argentina", "population": "45101781"})
countries.append({"name": "Brazil", "population": "212392717"})
countries.append({"name": "Colombia", "population": "49849818"})
countries.append({"name": "Ecuador", "population": "17100444"})
countries.append({"name": "Peru", "population": "32933835"})

然后你可以迭代它:

for country in countries:
    print(country)
# Result:
# Row(name='Argentina', population=45101781)
# Row(name='Brazil', population=212392717)
# Row(name='Colombia', population=49849818)
# Row(name='Ecuador', population=17100444)
# Row(name='Peru', population=32933835)
# "Row" is a namedtuple created from `country_fields`

# We've added population as a string, the library automatically converted to
# integer so we can also sum:
countries_population = sum(country.population for country in countries)
print(countries_population) # prints 357378595

還可以將此表導出為 CSV 或任何其他支持的格式:

# 公眾號:Python實用寶典
import rows
rows.export_to_csv(countries, "some-LA-countries.csv")

# html
rows.export_to_html(legislators, "some-LA-countries.csv")

從字典導入到rows對象:

import rows

data = [
    {"name": "Argentina", "population": "45101781"},
    {"name": "Brazil", "population": "212392717"},
    {"name": "Colombia", "population": "49849818"},
    {"name": "Ecuador", "population": "17100444"},
    {"name": "Peru", "population": "32933835"},
    {"name": "Guyana", }, # Missing "population", will fill with `None`
]
table = rows.import_from_dicts(data)
print(table[-1]) # Can use indexes
# Result:
# Row(name='Guyana', population=None)

3.命令行工具

除了寫Python代碼外,你還可以直接使用Rows的命令行工具,下面介紹幾個可能會經常被用到的工具。

讀取pdf文件內的文字并保存為文件:

# 需要提前安裝: pip install rows[pdf]
URL="http://www.imprensaoficial.rr.gov.br/app/_edicoes/2018/01/doe-20180131.pdf"
rows pdf-to-text $URL result.txt # 保存到文件 顯示進度條
rows pdf-to-text --quiet $URL result.txt # 保存到文件 不顯示進度條
rows pdf-to-text --pages=1,2,3 $URL # 輸出三頁到終端
rows pdf-to-text --pages=1-3 $URL # 輸出三頁到終端(使用 - 范圍符)

將csv轉化為sqlite:

rows csv2sqlite 
     --dialect=excel 
     --input-encoding=latin1 
     file1.csv file2.csv 
     result.sqlite

合并多個csv文件:

rows csv-merge 
     file1.csv file2.csv.bz2 file3.csv.xz 
     result.csv.gz

對csv執行sql搜索:

# needs: pip install rows[html]
rows query 
    "SELECT * FROM table1 WHERE inhabitants > 1000000" 
    data/brazilian-cities.csv 
    --output=data/result.html
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 編輯器
    +關注

    關注

    1

    文章

    803

    瀏覽量

    31129
  • python
    +關注

    關注

    56

    文章

    4783

    瀏覽量

    84473
  • csv
    csv
    +關注

    關注

    0

    文章

    38

    瀏覽量

    5808
收藏 人收藏

    評論

    相關推薦

    [下載]教你用Protel DXP的抄板功能

    教你用Protel DXP的抄板功能下載地址:http://www.ctpcb.cn/read.php?tid-8329199.html[此貼子已經被作者于2008-10-28 8:36:52編輯過]
    發表于 07-21 19:20

    [下載]教你用Protel ***的抄板功能

    教你用Protel ***的抄板功能下載地址:http://www.ctpcb.cn/read.php?tid-8329199.html
    發表于 09-25 09:28

    手把手教你用51單片機DIY音樂頻譜顯示

    `手把手教你用51單片機DIY音樂頻譜顯示`
    發表于 08-15 23:13

    教你用單片機控制LCD液晶顯示器

    教你用單片機控制LCD液晶顯示器
    發表于 08-20 21:25

    手把手教你用matlab生成STM32官方IIR濾波器系數

    手把手教你用matlab生成STM32官方IIR濾波器系數.pdf手把手教你用 matlab 生成 STM32 官方 IIR 濾波器的系數 (一)本文采用的 matlab 版本為 R2008a,芯片
    發表于 08-09 06:05

    matlab stm32 參數,手把手教你用matlab生成STM32官方IIR濾波器系數.pdf 精選資料分享

    手把手教你用matlab生成STM32官方IIR濾波器系數.pdf手把手教你用 matlab 生成 STM32 官方 IIR 濾波器的系數 (一)本文采用的 matlab 版本為 R2008a,芯片
    發表于 08-10 06:51

    教你用4路運放親手打造一個3通道混音器電源

    教你用4路運放親手打造一個3通道混音器電源2019年2月“電源”主題精選干貨大盤點!電磁干擾學院推薦 | EMC整改–常用小方法文看懂EMC防護器件之TVS...
    發表于 01-03 08:09

    教你用Word 2010變體字(三兩下就搞定)

    教你用Word 2010變體字(三兩下就搞定)  Word的字體可以幫助你干什么?突出你鮮明的個性?讓你的文章更加容易閱讀?不管它對你有什么益處,多
    發表于 04-03 09:12 ?2604次閱讀

    教你用熱像儀檢測鋰電池

    教你用熱像儀檢測鋰電池
    發表于 02-07 13:26 ?13次下載

    如何通過pandas讀取csv文件指定的前幾行?

    今天小編給大家分享一篇Python技術開發方面的文章,如何實現pandas讀取csv文件指定的前幾行,喜歡Python開發的小伙伴下面就隨小編一起來了解一下吧。
    發表于 09-19 17:43 ?16次下載

    一步一步教你用Zview擬合交流阻抗譜

    一步一步教你用Zview擬合交流阻抗譜(穩壓電源技術參數)-一步一步教你用Zview擬合交流阻抗譜 ? ? ? ? ? ? ??
    發表于 08-31 13:03 ?7次下載
    一步一步<b class='flag-5'>教你用</b>Zview擬合交流阻抗譜

    介紹Python中常用的文件讀取方法以及應用示例

    ython 文件讀取是 Python 語言中的基本操作之一。在編寫Python 程序時,我們經常需要讀取不同的文件,例如文本
    的頭像 發表于 04-27 09:16 ?1024次閱讀

    教你用NE555定時器做個防盜報警器

    今天繼續給大家分享一個小制作,教你用一個簡單的方法做一個防盜報警器,我想大家應該都知道現在無論是電動車上還是汽車上都具備防盜報警器
    的頭像 發表于 11-15 14:33 ?1800次閱讀
    <b class='flag-5'>教你用</b>NE555定時器做個防盜報警器

    python解析netflow數據到csv的流程詳解

    本文主要講解了linux下通過tcpdump抓取netflow數據包,并將其導入到wireshark進行解析,然后通過wireshark導出數據為json文件,再通過python腳本將其解析為csv
    的頭像 發表于 05-01 11:18 ?634次閱讀
    <b class='flag-5'>python</b>解析netflow數據到<b class='flag-5'>csv</b>的流程詳解

    如何實現Python復制文件操作

    Python 中有許多“開蓋即食”的模塊(比如 os,subprocess 和 shutil)以支持文件 I/O 操作。在這篇文章中,你將會看到一些
    的頭像 發表于 07-18 14:53 ?382次閱讀