久久精品草-久久精品成人-久久精品成人免费网站-久久精品成人欧美大片免费-香港三级大全-香港三级日本三级a视频

關于matlab中textread

2017-02-21  by:CAE仿真在線  來源:互聯網

今天打算跑下程序,突然發現,真的很爛,不會讀入數據,簡單的Iris.txt一上午都沒讀進去,在此對matlab中的textread函數做下總結,textscan函數待續。

本文主要內容引自http://linux.chinaitlab.com/administer/872894.html

筆者在此基礎上進行運行,修改得到以下內容,希望大家給與補充:

textread

基本語法是:

[A,B,C,…] = textread(filename,format)

[A,B,C,…] = textread(filename,format,N)
其中filename就是文件名, format就是要讀取的格式,A,B,C就是從文件中讀取到的數據。
必須嚴格遵守用法不可出現data=textread(filename,format,N)的形式

其中括號里面變量的個數必須和format中定義的個數相同。 如果每N行相同格式的數據,可采用[A,B,C,…] = textread(filename,format,N)的語法,讀取N次。
_______________________________________________________________________________________

注:textread不用先fopen那個文件,適用于格式統一的txt文件的一次性大批量讀取。textread讀取某個文件后,下次再用textread讀取這個文件時,還是會從文件頭開始讀取。

________________________________________________________________________________________

例如:
.....................................................................................
例1:無分隔符
mytest.txt
1 2 3 4
5 6 7 8
9 10 11 12

讀取:
>>[data1,data2,data3,data4]=textread('mytest.txt','%n%n%n%n');
>>data=[data1 data2 data3 data4]
data =

1 2 3 4
5 6 7 8
9 10 11 12
或者,[data1,data2,data3,data4]=textread(filename,'%n%n%n%n',3);%注意3為讀取次數,應該是行數
....................................................................................

例2:有分隔符(逗號,分號...)
myfile.txt 中的內容如下:

1, 2, 3, 4

5, 6, 7, 8

9, 10, 11, 12

讀取:
>> [data1,data2,data3,data4]=textread('myfile.txt','%n%n%n%n','delimiter', ',')
>> data=[data1 data2 data3 data4]

data =

1 2 3 4
5 6 7 8
9 10 11 12
這里delimiter是指 指出分隔符,讀數據的時候會自動跳過分隔符。

至此應該知道Iris.txt怎么讀入了吧。
[data1,data2,data3,data4,data5]=textread('Iris.txt','%f%f%f%f%s','delimiter',',');

需要注意的是,參數位置要和textread函數用法對應
[A,B,C,…] = textread(filename,format,N)也就是filename,format,N三個參數必須在其他參數前面,所以150才會出現在format后
例如:[data1,data2,data3,data4,data5]=textread('Iris.txt','%f%f%f%f%s',150,'delimiter',',');
..............................................................................

例3:有分隔符及首行注釋
myfiles.txt 中的內容如下:

% this a comment

1, 2, 3, 4

5, 6, 7, 8

9, 10, 11, 12

>> [data1,data2,data3,data4]=textread('myfiles.txt','%n%n%n%n','delimiter', ',','headerlines', 1);
>> data=[data1 data2 data3 data4]

data =

1 2 3 4
5 6 7 8
9 10 11 12
textread中的headerlines指明了跳過幾行,1可自由設定
這里headerlines告訴textread跳過一開始的1行,1可以替換為任意你要跳過的行數。
..............................................................................

例4:針對txt文件不同格式數據的讀取

myfile.txt 中的內容如下:

Sally Level1 12.34 45 Yes

讀入:
[names, types, x, y, answer] = textread('myfileli4.txt' , '%s %s %f %d %s', 1);

對應格式[A,B,C,…] = textread(filename,format,N)
_________________________________________________________________________________

例4.1: 如果要忽略12.34這個浮點數。

[names, types, y, answer] = textread('myfileli4.txt' , '%s %s %*f %d %s', 1)

%*f 告訴textread跳過一個浮點數。
names =

'Sally'


types =

'Level1'


y =

45


answer =

'Yes'

對于iris.txt如果只想讀取數據可用[data1,data2,data3,data4]=textread('Iris.txt','%f %f %f %f %*s',150,'delimiter',',');
____________________________________________________________________________________________

例:4.2 如果要忽略Level,指讀取后面的數字,

>> [names, levelnum, x, y, answer] = textread('myfileli4.txt','%s Level%d %f %d %s', 1)

names =

'Sally'


levelnum =

1


x =

12.3400


y =

45


answer =

'Yes'
________________________________________________________________________________________________
..............................................................OK ...............................................
例5: txt中存在空位

myfileli5.txt 中的內容如下
1,2,3,4,,6

7,8,9,,11,12

想用nan替代為空的部分

如下:
>>[data1 data2 data3 data4 data5 data6] = textread('myfileli5.txt','%f%f%f%f%f%f', 'delimiter', ',', 'emptyvalue', NaN)

>> data=[data1 data2 data3 data4 data5 data6];
>> data

data =

1 2 3 4 NaN 6
7 8 9 NaN 11 12

....................................................................................................................

例6: 跳列

myfileli6.txt 中的內容如下

Sally Type1 12.34 45 Yes

Joe Type2 23.54 60 No

Bill Type1 34.90 12 No

如果只想讀第一列,其余的跳過

讀入:
>> clear
>> [names]=textread('myfileli6.txt','%s%*[^\n]');
>> names

names =

'Sally'
'Joe'
'Bill'

%[^\n] 就是一直讀到行尾。
如:
>> [names rest]=textread('myfileli6.txt','%s%[^\n]')

names =

'Sally'
'Joe'
'Bill'


rest =

'Type1 12.34 45 Yes'
'Type2 23.54 60 No'
'Type1 34.90 12 No'

%*[^\n] 就是從當前直接跳到行尾。
% *是一個跳過符號,表示跳過該位

....................................................................................

例7:讀入規律格式的數據

myfileli7.txt 中的內容如下

Location;date;discharge

Lobith;1989-01-01;00:00;2801

Lobith;1989-01-02;00:00;2619

讀入:
[location year month day hour minute discharge]=textread('myfileli7.txt','%s%f-%f-%f%f:%f%f','headerlines',1,'delimiter',';');

如下:
>> clear
>> [location year month day hour minute discharge]=textread('myfileli7.txt','%s%f-%f-%f%f:%f%f','headerlines',1,'delimiter',';')

location =

'Lobith'
'Lobith'


year =

1989
1989


month =

1
1


day =

1
2


hour =

0
0


minute =

0
0


discharge =

2801
2619












開放分享:優質有限元技術文章,助你自學成才

相關標簽搜索:關于matlab中textread MatLab培訓 MatLab培訓課程 MatLab在線視頻教程 MatLab技術學習教程 MatLab軟件教程 MatLab資料下載 MatLab代做 MatLab基礎知識 Fluent、CFX流體分析 HFSS電磁分析 Ansys培訓 Abaqus培訓 

編輯
在線報名:
  • 客服在線請直接聯系我們的客服,您也可以通過下面的方式進行在線報名,我們會及時給您回復電話,謝謝!
驗證碼

全國服務熱線

1358-032-9919

廣州公司:
廣州市環市中路306號金鷹大廈3800
電話:13580329919
          135-8032-9919
培訓QQ咨詢:點擊咨詢 點擊咨詢
項目QQ咨詢:點擊咨詢
email:kf@1cae.com




主站蜘蛛池模板: 久久免费动漫品精老司机 | 亚洲激情 | 99r在线播放 | 99热在线看| 特级aaa毛片 | eeuss影院在线奇兵区1页 | 自拍偷拍欧美亚洲 | 精品国产污污免费网站 | 女人张开腿让男人捅app | 国产高清视频网站 | 99热这里只有精品9 99热这里只有精品88 | 人人人干 | 色综合久久久久久久久久久 | 成人国产亚洲欧美成人综合网 | 色综合久久88色综合天天 | 欧美视频久久久 | 国产日韩欧美91 | 香蕉视频破解版 | 女老师1 | 精品在线播放视频 | 亚洲香蕉久久一区二区三区四区 | 九九热九九 | 视频一区在线播放 | 欧美成人精品一区二区 | 精品国产高清不卡毛片 | 日韩一级特黄毛片在线看 | 九九视频在线免费观看 | 一级特黄aaa大片在线观看 | 国产色视频网站免费观看 | 国产精品久久久久国产精品三级 | 2019国内精品久久久久久 | 免费的看黄网站 | 成人羞羞视频在线 | 亚州一级毛片 | 亚洲欧美韩国日本 | 久久er精品视频 | 欧美日韩国产精品自在自线 | 成年人免费在线视频网站 | 亚洲国产一区在线精选 | 日一日操一操 | 鲁大师成人精品视频 |