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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...