24小时热门版块排行榜    

查看: 3376  |  回复: 5

jhl2011

新虫 (小有名气)

[求助] 求助关于importdata函数的问题 已有1人参与

求助一个关于MATLAB importdata 函数的问题。用这个函数读取一个TXT文件,文件中第一行和第二行都是文本,从第三行到最后都是数字,之前用这个函数读取可以将数字读取到 .data 里面,后来修改了txt文件的内容之后就发现出问题了。

经过研究可能是由于第一行文本过长导致MATLAB 当成了两行(在记事本打开后,取消自动换行后第一行(没有换行符)仍然显示为两行),读取结果是原来是六千多行一百多列的数据,读取到.data里面只有一列, .textdata 里面有 一万多行 八十多列,所以应该是第一行被MATLAB认为是两行了

所以求助一下有没有解决的办法?
删除第一和第二行是一个办法,但我想保留表头
手动导入可以导入成列向量并且直接用变量名,但我不知道怎么用m文件实现,因为要批量处理,如果可以实现这个是最好的。
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

csp101

金虫 (著名写手)

逐个读入数据,设计一个if判定吧,当出现第一行末尾的字符时选择跳行

发自小木虫Android客户端
2楼2016-07-09 23:44:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

jhl2011

新虫 (小有名气)

引用回帖:
2楼: Originally posted by csp101 at 2016-07-09 23:44:34
逐个读入数据,设计一个if判定吧,当出现第一行末尾的字符时选择跳行

你的意思是用读文本的方法一个一个字符读?这样的运行速度会不会慢很多,因为整个文本是有三千多行,每一行也很长。
3楼2016-07-14 08:36:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

csp101

金虫 (著名写手)

【答案】应助回帖

引用回帖:
3楼: Originally posted by jhl2011 at 2016-07-14 08:36:17
你的意思是用读文本的方法一个一个字符读?这样的运行速度会不会慢很多,因为整个文本是有三千多行,每一行也很长。...

运行速度是次要的,重要的是先能实现功能呀

发自小木虫Android客户端
4楼2016-07-14 23:19:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

jhl2011

新虫 (小有名气)

★ ★
jjdg: 金币+2, 感谢分销 2017-02-21 16:04:20
jjdg: 感谢分享 2017-02-21 16:04:39
自行回答这个问题,过了这么久终于发现原因了
在 matlab 中使用 importdata(filename) 这个函数的时候,它会判断哪些行属于 header, 哪些属于 data,可以调用 [A,delimiterOut,headerlinesOut] = importdata(filename) 就可以看出读出来有多少行是判定为 header。
那么问题就出现在判定标准上。
今天做了一下尝试,发现判定一行是否为 header 就在于它的最后一个字符是不是数字。
我的数据文件第一行为变量名,所以都是字母,第二行为单位,一开始的单位行最后一个是A,所以importdata函数判定为header,所以用上面函数读出来A变量中 a.data就是数据矩阵, headerlinesOut = 2 表明读到了两行header,正确。
后来用另一组数据,第二行最后是1,读出来 A.data是错的,headerlinesOut = 1,表明它把第二行当成是数据了,但读下来又存在非数字元素,所以都存到 A.textdata里面去了。
5楼2017-02-15 22:31:56
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

jhl2011

新虫 (小有名气)


jjdg: 金币+1, 感谢分享 2017-02-21 16:04:52
再增加一个小技巧,在matlab 用窗口打开数据文件之后,可以选择数据范围,变量名称等,选完之后在导入所选内容按钮下面有一个箭头,点击可以展开,下面有一项是生成脚本,可以把你当前导入数据的设置用脚本保存下来,我看了代码,可以参考用来打开数据文件。
主要是用textscan函数

%% 初始化变量。
filename = '。。。';
delimiter = ',';
startRow = 48;

%% 每个文本行的格式字符串:
%   列1: 文本 (%s)
%        列2: 双精度值 (%f)
%   列3: 双精度值 (%f)
%        列4: 双精度值 (%f)
%   列5: 文本 (%s)
%        列6: 文本 (%s)
%   列7: 文本 (%s)
%        列8: 文本 (%s)
%   列9: 文本 (%s)
%        列10: 文本 (%s)
%   列11: 文本 (%s)
%        列12: 文本 (%s)
%   列13: 文本 (%s)
%        列14: 文本 (%s)
%   列15: 文本 (%s)
%        列16: 文本 (%s)
%   列17: 文本 (%s)
%        列18: 文本 (%s)
%   列19: 文本 (%s)
%        列20: 文本 (%s)
%   列21: 文本 (%s)
%        列22: 文本 (%s)
%   列23: 文本 (%s)
% 有关详细信息,请参阅 TEXTSCAN 文档。
formatSpec = '%s%f%f%f%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%[^\n\r]';

%% 打开文本文件。
fileID = fopen(filename,'r');

%% 根据格式字符串读取数据列。
% 该调用基于生成此代码所用的文件的结构。如果其他文件出现错误,请尝试通过导入工具重新生成代码。
textscan(fileID, '%[^\n\r]', startRow-1, 'WhiteSpace', '', 'ReturnOnError', false);
dataArray = textscan(fileID, formatSpec, 'Delimiter', delimiter, 'EmptyValue' ,NaN,'ReturnOnError', false);

%% 关闭文本文件。
fclose(fileID);
6楼2017-02-20 15:31:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 jhl2011 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料工程(专)一志愿985 初试335求调剂 +3 hiloiy 2026-03-17 4/200 2026-03-21 03:04 by JourneyLucky
[考研] 299求调剂 +6 △小透明* 2026-03-17 6/300 2026-03-21 02:42 by JourneyLucky
[考研] 328求调剂,英语六级551,有科研经历 +4 生物工程调剂 2026-03-17 8/400 2026-03-21 02:12 by JourneyLucky
[考研] 297求调剂 +9 戏精丹丹丹 2026-03-17 9/450 2026-03-21 01:49 by JourneyLucky
[考研] 材料 336 求调剂 +3 An@. 2026-03-18 4/200 2026-03-21 01:39 by JourneyLucky
[考研] 271材料工程求调剂 +8 .6lL 2026-03-18 8/400 2026-03-21 00:58 by JourneyLucky
[考研] 354求调剂 +5 Tyoumou 2026-03-18 8/400 2026-03-21 00:35 by JourneyLucky
[考研] 304求调剂 +7 司空. 2026-03-18 7/350 2026-03-20 23:08 by JourneyLucky
[考研] 323求调剂 +3 洼小桶 2026-03-18 3/150 2026-03-20 22:54 by JourneyLucky
[考研] 材料与化工 322求调剂 +4 然11 2026-03-19 4/200 2026-03-20 22:12 by luoyongfeng
[考研] 329求调剂 +9 想上学吖吖 2026-03-19 9/450 2026-03-20 22:01 by luoyongfeng
[考研] 本人考085602 化学工程 专硕 +19 不知道叫什么! 2026-03-15 21/1050 2026-03-20 20:48 by zhukairuo
[考研] 一志愿吉林大学材料学硕321求调剂 +11 Ymlll 2026-03-18 15/750 2026-03-20 19:40 by 丁丁*
[考研] 281求调剂(0805) +14 烟汐忆海 2026-03-16 25/1250 2026-03-20 15:47 by yuncha
[考研] 081700化工学硕调剂 +3 【1】 2026-03-16 3/150 2026-03-19 23:40 by edmund7
[考研] 本科郑州大学物理学院,一志愿华科070200学硕,346求调剂 +4 我不是一根葱 2026-03-18 4/200 2026-03-19 09:11 by 浮云166
[考研] 0854可跨调剂,一作一项核心论文五项专利,省、国级证书40+数一英一287 +8 小李0854 2026-03-16 8/400 2026-03-18 14:35 by 搏击518
[考研] 考研化学学硕调剂,一志愿985 +4 张vvvv 2026-03-15 6/300 2026-03-17 17:15 by ruiyingmiao
[考研] 一志愿211 0703方向310分求调剂 +3 努力奋斗112 2026-03-15 3/150 2026-03-16 16:44 by houyaoxu
[考研] 0856求调剂 +3 刘梦微 2026-03-15 3/150 2026-03-16 10:00 by houyaoxu
信息提示
请填处理意见