久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

python使用NumPy文件的讀寫操作

瀏覽:2日期:2022-06-23 11:11:57
一、使用NumPy讀寫文本文件

在數據分析中,經常需要從文件中讀取數據或將數據寫入文件,常用的存儲文件的格式有文本文件、CSV格式文件、二進制格式文件和多維數據文件等。

1.將1維或2維數組寫入TXT文件或CSV格式文件 在NumPy中,使用savetxt()函數可以將1維或2維數組寫入后綴名為txt或csv的文件.函數格式為:

**numpy.savetxt(fname,array,fmt=’%.18e’,delimiter=None,newline=’n’, header=’’, footer=’’, comments=’# ’, encoding=None)**

主要參數:fname:文件、字符串或產生器,可以是.gz 或.bz2 的壓縮文件array:存入文件的數組(一維數組或者二維數組)fmt:寫入文件的格式,如:%d,%.2f,%.18e,默認值是%.18e 可選項delimiter: 分隔符,通常情況是str可選header:將在文件開頭寫入的字符串footer:將在文件尾部寫入的字符串comments: 將附加到header和footer字符串的字符串,以將其標記為注釋。默認值:’#’ encoding:用于編碼輸出文件的編碼。

import numpy as nparr = np.arange(12).reshape(3,4)#fmt缺省取%.18e(浮點數)#分割符默認是空格,寫入文件保存在當前目錄np.savetxt(’test-1.txt’,arr)#fmt:%d 寫入文件的元素是十進制整數,分割符為逗號',',寫入文件保存在當前目錄np.savetxt(’test-2.txt’,arr,fmt=’%d’,delimiter=’,’)#在test-3.txt文件頭部和尾部增加注釋,頭部 #test-3,尾部 # 數據寫入注釋,寫入文件的元素是字符串np.savetxt(’test-3.txt’,arr,fmt=’%s’,delimiter=’,’,header= ’test-3’,footer=’測試數據’,encoding=’utf-8’)#在test-4.txt文件頭部加##test-4注釋np.savetxt(’test-4.txt’,arr,fmt=’%f’,delimiter=’,’,header= ’test-4’,comments=’###’)#將arr數組保存為csv文件np.savetxt(’test-1.csv’,arr,fmt=’%d’,header=’test-1’)2.讀取TXT文件和CSV格式文件 在NumPy中,讀取TXT文件和CSV格式文件的函數是loadtxt(),函數格式:

numpy.loadtxt(fname,dtype=type’float’>,comments=’#’,delimiter=None, converters=None,skiprows=0,usecols=None,unpack=False,ndmin=0,encoding=‘bytes’)#參數說明:fname:被讀取的文件名(文件的相對地址或者絕對地址)dtype:指定讀取后數據的數據類型comments: 跳過文件中指定參數開頭的行(即不讀?。ヾelimiter:指定讀取文件中數據的分割符converters: 對讀取的數據進行預處理skiprows:選擇跳過的行數usecols:指定需要讀取的列unpack:選擇是否將數據進行向量輸出encoding:對讀取的文件進行預編碼

a = np.loadtxt(’test-1.txt’) #讀入當前目錄下的文件 test-1.txtprint(a) [[ 0. 1. 2. 3.] [ 4. 5. 6. 7.] [ 8. 9. 10. 11.]]

# skiprows:指跳過前1行, 如果設置skiprows=2, 就會跳過前兩行,數據類型設置為整型.a = np.loadtxt(’test-1.txt’, skiprows=1, dtype=int)print(a)[[ 4 5 6 7] [ 8 9 10 11]]

# comment, 如果行的開頭為#就會跳過該行a = np.loadtxt(’test-4.txt’, skiprows=2, comments=’#’,delimiter=’,’)b = np.loadtxt(’test-4.txt’,comments=’#’,delimiter=’,’)print(a,b,sep=’n’)[[ 4. 5. 6. 7.] [ 8. 9. 10. 11.]][[ 0. 1. 2. 3.] [ 4. 5. 6. 7.] [ 8. 9. 10. 11.]]

# usecols:指定讀取的列,若讀取0,2兩列aa = np.loadtxt(’test-3.txt’,dtype=int, skiprows=1,delimiter=’,’,usecols=(0, 2))#unpack是指會把每一列當成一個向量輸出, 而不是合并在一起。(a, b) = np.loadtxt(’test-2.txt’, dtype=int, skiprows=1, comments=’#’, delimiter=’,’, usecols=(0, 2), unpack=True)print(aa,a, b,sep=’n’)[[ 0 2] [ 4 6] [ 8 10]][4 8][ 6 10]#讀取csv文件aa = np.loadtxt(’test-1.csv’,skiprows=1)print(aa)[[ 0. 1. 2. 3.] [ 4. 5. 6. 7.] [ 8. 9. 10. 11.]]二、使用NumPy讀寫二進制文件1.使用save()或savez()函數寫二進制格式文件

save函數將數組以未壓縮的原始二進制格式保存在擴展名為.npy的文件中。會自動處理元素類型和形狀等信息。savez函數將多個數組壓縮到一個擴展名為npz的文件,其中每個文件都是一個save()保存的npy文件,文件名和數組名相同save()或savez()函數的格式:

numpy.save(file,array)numpy.savez(file,array)2.使用load()函數讀取二進制格式文件

load()函數的格式: numpy.load(file)

import numpy as npa = np.arange(12).reshape(3,4)print(’原數組a:n’,a)np.save(’arr1.npy’, a) #將數據存儲為npy,保存時可以省略擴展名,默認.npyc = np.load(’arr1.npy’) #讀取arr1.npy的數據,讀取數據時不能省略 .npyprint(’讀取后的數據:n’,c)ar = np.arange(6).reshape(3,2) print(’保存前的數組:’,a,ar,sep=’n’)np.savez(’arr2.npz’,a,ar) #多數組存儲,默認文件名.npzb = np.load(’arr2.npz’)print(’讀取后的數據:’)print(b[’arr_0’],b[’arr_1’],sep=’n’)

原數組a:[[ 0 1 2 3][ 4 5 6 7][ 8 9 10 11]]讀取后的數據:[[ 0 1 2 3][ 4 5 6 7][ 8 9 10 11]]保存前的數組:[[ 0 1 2 3][ 4 5 6 7][ 8 9 10 11]][[0 1][2 3][4 5]]讀取后的數據:[[ 0 1 2 3][ 4 5 6 7][ 8 9 10 11]][[0 1][2 3][4 5]]

for i in b.items(): print(i)(’a’, array([[ 0, 1, 2, 3], [ 4, 5, 6, 7], [ 8, 9, 10, 11]]))(’ar’, array([[0, 1], [2, 3], [4, 5]]))

以上就是python使用NumPy文件的讀寫操作的詳細內容,更多關于python使用NumPy讀寫文件的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 黔南| 临夏市| 友谊县| 甘肃省| 衡水市| 文水县| 海盐县| 三门县| 中卫市| 平武县| 苍南县| 沙雅县| 兴化市| 昌宁县| 辽源市| 盐津县| 焉耆| 新巴尔虎左旗| 金华市| 昂仁县| 天台县| 井冈山市| 塔城市| 巴彦县| 扶沟县| 龙川县| 行唐县| 灵丘县| 克什克腾旗| 定结县| 沈阳市| 松溪县| 宁海县| 襄垣县| 板桥市| 长武县| 扶绥县| 福州市| 屯留县| 英德市| 繁峙县|