python數據文件讀寫

来源:https://www.cnblogs.com/trialley/archive/2019/03/04/10474007.html
-Advertisement-
Play Games

"CSV" 格式讀寫 Comma Separated Values 有時也稱為字元分隔值,因為分隔字元也可以不是逗號。以 分隔的文件叫csv,以 分隔的叫tsv 需要註意的一點:分隔符 如果文件是其他分隔符,如 ,則需要傳入分隔符類型。 讀取 列表方式讀取 字典方式讀取 寫入 列表方式寫入 字典方式 ...


CSV格式讀寫

Comma-Separated Values 有時也稱為字元分隔值,因為分隔字元也可以不是逗號。以,分隔的文件叫csv,以\t分隔的叫tsv

需要註意的一點:分隔符

import csv 

data=[]
with open(r'data.csv',) as csvfile:
    file_list = csv.reader(csvfile,'mydialect')
    for line in file_list:
        data.append(line)
print(data)

如果文件是其他分隔符,如\n,則需要傳入分隔符類型。

import csv 

data=[]
with open(r'data.csv',) as csvfile:
    file_list = csv.reader(csvfile,delimiter='\t')
    for line in file_list:
        data.append(line)
print(data)

讀取

列表方式讀取

import csv

with open('data.csv','r',encoding='utf-8') as csvfile:
    reader = csv.reader(csvfile)
    for row in reader:
        # 讀取出的內容是列表格式的
        print(row,type(row),row[1])

字典方式讀取

import csv

with open('data.csv','r',encoding='utf-8') as csvfile:
    reader = csv.DictReader(csvfile)
    for row in reader:
        # 讀取的內容是字典格式的
        print(row['last_name'])

寫入

列表方式寫入

import csv

with open('data.csv','a+',encoding='utf-8',newline='') as csvfile:
    writer = csv.writer(csvfile)

    # 寫入一行 
    writer.writerow(['1','2','3','4','5','5','6'])

    # 寫入多行
    writer.writerows([[0, 1, 3], [1, 2, 3], [2, 3, 4]])

字典方式寫入

import csv
with open('data.csv','a+',encoding='utf-8',newline='') as csvfile:
    filename = ['first_name','last_name']
    # 寫入列標題
    writer = csv.DictWriter(csvfile,fieldnames=filename)
    writer.writeheader()
    writer.writerow({'first_name':'wl','last_name':'wtx'})
    writer.writerow({'first_name': 'Lovely', 'last_name': 'Spam'})
    writer.writerow({'first_name': 'Wonderful', 'last_name': 'Spam'})

json格式讀寫

python內置json包提供了四個函數:dumps、dump、loads、load。不帶s的負責文件與字典的轉換。帶s的負責字元串和字典的轉換。

字典到字元串 string json.dumps(dict)

import json

test_str = json.dumps({'name' : "cat"})

字元串到字典 dict json.loads(string)

import json

test_dict = json.loads("{'name' : "cat"}")

字典到json文件 json.dump(dict, file)

import json

with open("test.json","w") as f:
    json.dump({'name' : "cat"}, f)

json文件到字典 dict json.load(file)

import json

with open("test.json",'r') as f:
    test_dict = json.load(f)

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

-Advertisement-
Play Games
更多相關文章
  • ""中文編程"知乎專欄原文" 源碼: "program in chinese/jinxiaocun" 由於這個演示項目成型於去年(詳見 "中文編程的嘗試歷程小記" ), Spring Boot還是老版本. 尚未將其更新到最新版本, 先將其中的一些中文命名的部分小結在此. URL 如: /商品表 /單 ...
  • 如果你要確定文件存在的話然後做些什麼,那麼使用try是最好不過的 如果您不打算立即打開文件,則可以使用os.path.isfile檢查文件 如果path是現有常規文件,則返回true。對於相同的路徑,islink()和isfile()都可以為true 如果你需要確定它是一個文件。 從Python 3 ...
  • 1.數值類型與進位 (1)基本類型 輸出結果: (2)進位 進位轉換 (3)基本運算 舍掉小數 輸出結果: 科學計數法 輸出結果: 2.運算符 (1)算術運算符 (2)比較運算符 (3)賦值運算符 (4)位運算符 我沒用過。。就不寫了。 (5)邏輯運算符 (6)成員運算符 (7)身份運算符 ...
  • ""中文編程"知乎專欄原文" 看到 "國人創造中文編程語言的優勢" 一文的評論後, 此文基於個人視野, 從幾個方面闡述中文編程興起的必然性和展望. 下麵是一些近十幾年中的相關趨勢. 對代碼可讀性的重視將會從大公司向小公司逐漸普及 在這個2010年的 "Quara回答" 中, Google已經把可讀性 ...
  • 方法的定義 如果沒有=和{}包裹的方法體,那麼該方法被隱式申明為抽象(abstract)方法,包含它的類就是抽象類。 當輸入相同類型的參數個數無法確定時,可以使用變長參數,如:def sum(args : Int*) = {for(arg <- args) println(arg)}。 如果方法體直 ...
  • 今天佛了,魔鬼周一,線上教學,有點小累,但還好,今天AC了一道,每日一道,還好達成目標,還以為今天完不成了,最近任務越來越多,如何高效完成該好好思考一下了~最重要的還是學業的複習和預習。 今日興趣新聞: 《流浪地球》中的逃生氣囊球和馬斯克有什麼關係? 鏈接:https://mbd.baidu.com ...
  • 由於最近在剛開始做一個前臺element和mybatisplus的項目,但是在使用nodejs下載vue的腳手架和各種組件時,會經常出現下載失敗的問題,進而導致前臺無法啟動。 在網上查詢之後發現在下載時建議使用國內的淘寶鏡像下載。具體操作就是在原本的命令前加一個c。比如npm install,那麼從 ...
  • 學習一門語言最重要的一步是搭建環境,許多人搭建在搭建環境上撞牆了,就有些放棄的心理了;俗話說,工欲善其事,必先利其器;所以接下來我們進行學習C的第一步搭建環境; 第一步:先解壓我們下載好的VC6.0軟體壓縮包,軟體我會在文章下麵打包。 第二步:雙擊打開我們解壓好的文件夾里的VC6.0完整綠色版.ex ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...