https://blog.csdn.net/u014453898/article/details/73378463
1.實例程序:
''' 數據文件:2.txt內容:(以空格分開每個數據) 1 2 2.5 3 4 4 7 8 7 ''' from numpy import * A = zeros((3,3),dtype=float) #先創建一個 3x3的全零方陣A,並且數據的類型設置為float浮點型 f = open('2.txt') #打開數據文件文件 lines = f.readlines() #把全部數據文件讀到一個列表lines中 A_row = 0 #表示矩陣的行,從0行開始 for line in lines: #把lines中的數據逐行讀取出來 list = line.strip('\n').split(' ') #處理逐行數據:strip表示把頭尾的'\n'去掉,split表示以空格來分割行數據,然后把處理后的行數據返回到list列表中 A[A_row,:] = list[0:3] #把處理后的數據放到方陣A中。list[0:3]表示列表的0,1,2列數據放到矩陣A中的A_row行 A_row+=1 #然后方陣A的下一行接着讀 #print(line) print(A) #打印 方陣A里的數據 打印結果: [[ 1. 2. 2.5] [ 3. 4. 4. ] [ 7. 8. 7. ]]
2.數據讀入矩陣的邏輯:
為簡單解釋,例如我們要把:
1 2 3
4 5 6
7 8 9
讀入矩陣中,以上述的代碼為例:
當 A_row =0時,執行 A[A_row:] = list[0:3] 后矩陣A是:
1 | 2 | 3 |
1 | 2 | 3 |
1 | 2 | 3 |
當A_row = 1是,執行 A[A_row:] = list[0:3] 后矩陣A是:
1 | 2 | 3 |
4 | 5 | 6 |
4 | 5 | 6 |
當A_row = 2時,執行 A[A_row:] = list[0:3] 后矩陣A是:
1 | 2 | 3 |
4 | 5 | 6 |
7 | 8 | 9 |
也就是上述代碼:
for line in lines: #先把逐行數據取出來 list = line.strip('\n').split(' ') #再通過處理,放回到list列表中 A[A_row:] = list[0:3] #然后把list列表的數據放到矩陣中 A_row+=1
所做的事情。