首页
博客
研修院
VIP
APP
问答
下载
社区
推荐频道
活动
招聘
专题
打开CSDN APP
Copyright © 1999-2020, CSDNNET, All Rights Reserved
读取文件
打开APP
MATLAB读取列数不一致的文件(1、跳过前面N行数据,2、读取每行列数不同数据) 原创
2019-06-26 10:18:27
12点赞
阿GEM是我的
码龄5年
关注
MATLAB常见的读取加载数据文件都是用load 、importdata之类比较多,该类方法多局限于文件数据每一行的列数都是相等的;
但是如果遇到的数据文件前面N行数据是英文或中文,剩下的是列数相等的数据,那这类导入方法有点不行了,例如数据文件长这样:
我们要读取的是后面列数相同的浮点型数据,保存在一个矩阵中,需要跳过前面11行数据(这是一个点云文件,pcd格式),代码和结果如下:
TrFid = fopen(TrPath,'r'); % 路径
FormatString='%f %f %f %[^\n]'; % 读取数据的类型
% 参数依次是 文件、数据类型、读取行数(可选)、跳过前面11行数据、空格为数据分割符
Ctr = textscan(TrFid, FormatString, NUM, 'HeaderLines', 11, 'delimiter', ' ');
Ctr = cell2mat(Ctr); % 转矩阵
fclose(TrFid);
当我们不需要跳过前面的N行数据,只是每一行的列数不一致,需要分开读取每一行并将每一行数据保存在单独的数组中,如数据文件长这样:
代码和结果如下:
% matlab读取不同列的数据
clc;clear all;
str = 'D:\VS_Files\Lidar\Project2\cloud_point\train_sample\RGB_dataset_pcd\testtxt';
fid = fopen(str);
while ~feof(fid) % 判断有没有到文件结尾
tline = fgetl(fid); % 每读取完一行数据后,自动地位到下一行
a = str2num(tline)
if isempty(tline) % 判断该行是否为空
continue
end
end
fclose(fid);
点击阅读全文
打开CSDN APP,看更多技术内容
matlab读取不同文件文件,Matlab – 读取不同行长的文件
虽然如果您的文本文件中没有任何零值,Divakar的答案仍然有效,但通常情况并非如此例如,如果您的文本数组是1 2 34 05 6 0 7 8然后Divakar的结果将是:1 2 3 nan nan4 nan nan nan nan5 6 nan 7 8而你真的想要:1 2 3 nan nan4 0 nan nan nan5 6 0 7 8实现这一点的最简单方法是打开dlmread函数(只需在文
继续访问
matlab对每一行数据不等的txt文件读取问题
文件读取方法 目标:读取每一行数字数目不同的纯文本文件。形如: 9 2 8 9 7 3 4 6 8 9 0 0 2 8 7 4 0 1 6 0 0 8 0 2 7 4 4 6 2 8 0 2 7 8 0 2 6 8 0 2 0 5 0
继续访问
热门推荐 MATLAB数据导入(importdata函数)
编写程序时,有时需要从外部读入数据,这里介绍用importdata函数把数据导入MATLAB的方法。 1加载和显示图像文件 在MATLAB中建立一个脚本文件,内容如下: filename = 'mingpng'; A = importdata(filename); image(A); 运行该文件,MATLAB显示出图像文件。 注意:该图像文件必须保存在当前目录。 2 导入文本文件
继续访问
matlab从第N行开始读取dat数据
遇到了这样的一个问题,在matlab中要读取下面dat文件中的数据存到数组中。 但是,最前面的一行是数据提示语,例如第一列的rcs代表下面的数据是雷达目标的rcs,第二列的fre代表其对应的频率。我们要读到matlab中要进行处理的数据当然不包括第一行的rcs和fre。所以怎么跳过第一行直接读后面的呢? 尝试过load和fscanf函数,好像都不行。最后找到了一个textscan函数可以实现这个目的。下面是代码以及运行结果: clc;clear;close all; fid=fopen('rcsdat'
继续访问
matlab 行 读取文件 跳过_Matlab读取TXT文件并跳过中间几行的问题!!
#!MLF!#"/group1rec"011300000sil-3797347412SENT-START1130000011600000dh-156719879the1160000011900000ax-2084651641190000011900000sp-12039731190000012500000ih-4825331#!MLF!#"/group1rec"0 1130
继续访问
matlab读取列数不同的txt文件
文章目录背景用textread或dlmread函数参考 背景 matlab读取列数不同的txt文件,一般只能读取里面是数字的txt文件,而且一般用load('atxt'); 但当txt文件里每行的数字不同时,就不能用load函数了,会报错: 用textread或dlmread函数 当txt文件是每行的数字不一定相同的文件时: 则使用代码: textread('二机五节点数据txt') 或
继续访问
MATLAB读取文件夹下的多个TXT文件,并将长度不一致的数据按顺序写入到Excel对应各列中
MATLAB读取文件夹下的多个TXT文件,并将长度不一致的数据按顺序写入到Excel对应各列中 clear clc %% mydir = '包含多个TXT的文件夹'; if mydir(end) ~= '/' mydir = [mydir, '/']; end dirs = dir([mydir, 'txt']); %扩展名 dirs = struct2cell(dirs)';
继续访问
matlab怎么批量删除文件中的前几行_教程合集 | python文件读写
叮铃铃!中国假期管理局提醒您,国庆假期还有3天余额。节前立下的FLAG都实现了吗?有在好好学习吗(反正小编的FLAG是倒了一片)。Python以库闻名天下,然而名目繁多的库却让小白同学们常头昏脑涨不知如何选择。今天跟着小编一起梳理一下都有哪些库可以读写文件吧!让假期不再虚度~1Python自带方式 Python自带的文件打开函数是open及with open,使用方式为:
继续访问
matlab 行 读取文件 跳过_MATLAB读取列数不一致的文件(1、跳过前面N行数据,2、读取每行列数不同数据)
MATLAB常见的读取加载数据文件都是用load 、importdata之类比较多,该类方法多局限于文件数据每一行的列数都是相等的;但是如果遇到的数据文件前面N行数据是英文或中文,剩下的是列数相等的数据,那这类导入方法有点不行了,例如数据文件长这样: 我们要读取的是后面列数相同的浮点型数据,保存在一个矩阵中,需要跳过前面11行数据(这是一个点云文件,pcd格式),代码和结果如下:TrFid = f
继续访问
mac系统python读取文件_0112编程-windows和mac的python文件读写编码
在python编程中,苹果macOS(linux、unix)的系统默认文件数据读写编码是utf-8,而windows系统默认是gbk。所以很多在mac中正常运行的with open却可能在mac下出错。下面是mac和win的几个对比:读取所有文件列表macOSimport osfiles=oslistdir('/Users/zhyuzh/Desktop/Jupyter/tutor/jo
继续访问
MATLAB中的cumsum()函数 计算一个数组各行的累加值
matlab中cumsum函数通常用于计算一个数组各行的累加值。在matlab的命令窗口中输入doc cumsum或者help cumsum即可获得该函数的帮助信息。 格式一:B = cumsum(A) 这种用法返回数组不同维数的累加和。 如果A是一个向量, cumsum(A) 返回一个向量,该向量中第m行的元素是A中第1行到第m行的所有元素累加和; 如果A是一
继续访问
Matlab从txt第二行开始读,MATLAB小技:从文本数据第n行开始读取
因为文本数据中第一行会有留白,很多人介绍的方法都是手工删除前面的空白或空白和文字。个人觉得比较麻烦其实如果在MATLAB中可以用textread命令来控制从第N行开始读取数据。比如输出的原始数据,第1行是空白数据,第2行是数据名称,第3行是空白行,而有用数据是从第4行开始,如下所示:---------------------------------------------------------
继续访问
最新发布 基于MATLAB的微分方程的定步长与动步长算法对比解法(附完整代码)
目录 一 四阶定步长Runge-Kutta算法 二 四阶五级Runge-Kutta-Felhberg算法 三 微分方程求解函数 31 求解格式 32 描述微分方程组 例题1 例题2 一 四阶定步长Runge-Kutta算法 令h代表计算步长,该算法的主题思想如下: 下一个步长的状态变量值,可计算如下: 形成MATLAB代码如下: function [tout,yout]=rk_4(odefile,tspan,y0) %y0初值列向量 t0=tsp
继续访问
五种matlab读取excel文件方法
读取excel文件的五种方式: readcell(filename),以cell(元胞数组,注:访问cell元素用{ })格式导入所有信息,空格被识别为missing。用strcmp(class(references{2,3}),'missing')来判定,若为1,则说明为空。最省事的方法。 [NUM,TXT,RAW]=xlsread(filename) NUM返回的是excel中的数据,TXT输出的是文本内容,RAW输出的是未处理数据。一般情况下,我们直接用reference=xlsread('exa
继续访问
matlab读取txt数据文件
一、load()函数 load函数适合读取纯数据文本 例子,data_txttxt内容如下: 0 1000000 2000000 3000000 1 3000000 4000000 5000000 2 6000000 7000000 8000000 3 9000000 1000000 1100000 读取代码如下: %对于类似的txt文件,不含有字符,只有数字 data=load(‘data_tx
继续访问
matlab 行 读取文件 跳过_matlab中textscan跳行使用
Matlab的textscan指令2010-03-0211:33:10最近在玩学长给的一个资料档,里头有文字和数据混何在一起,要用Matlab来读取要是以前的话,大概就很笨的用手动的方式把文字去掉,再让Matlab来读不过最近才发现Matlab7的一个新指令textscan可以很方便的协助读取文字档中的字串与数据矩阵利用这个指令很快的就完成读取文字档中数个不同大小的数字矩阵了textsc
继续访问
matlab读取不规则txt文件,如何读取数据不规则的ascii/txt文件?
ETASAsciiItemFile record CrLf TabsampleCount 196951time sVcScIn_v_VehSpdLgt\ETKC:1 sVcDtcAtr_n_IsgCrSh\ETKC:1 sVcEc_n_Eng\ETKC:1 sVcVmcEm_X_SocH
继续访问
2021-06-02 matlab自动选取步长的复化梯形求积算法代码及自学笔记
matlab自动选取步长的复化梯形求积算法代码及自学笔记 思想:用梯形面积近似积分面积,自动划分积分区间(将区间逐次二分),直到误差小于给定的误差限eps 首先,将给定区[a,b]进行n等分,得到n+1个节点(k=0,1,2n),利用公式(1)计算梯形面积和近似等于函数积分,需要计算函数在n+1个节点处的函数积分f(); 将求积区间再次二等分,得到2n+1个节点,新增n个节点,记二分前的某个区间为[,],(k=0,1,2n-1),对该区间进行二等分,新增节点为=(+)/2,(k=0,1,2
继续访问
matlab中load加载报错:错误使用 load ASCII 文件 E:\毕业设计\data\Untitled3m 的第 3 行中的列数必须与前面行中的列数相同。
之前在网上找了很久关于这个load加载报错的,百度说的什么方法都试了一遍,发现还是不行,于是去请教了学长,终于把这个问题解决了。因为我处理的数据时蛋白质序列的,需要两个参数,所以就这样解决了: 把cell类型的用P_test变量代替,具体的原理我也是不懂的哈。其实P_test是一个变量,然后保存你要的两个数据,最后再加载就可以了。有知道原理的可以告诉我一下啊,希望对大家有用!
继续访问
解决Matlab中reshape报错:栅格影像行列数不一致的问题
今天在用Matlab做栅格数据偏相关分析的时候,遇到了如下问题: 参考此回答,可以了解reshape的用法 打开ArcGIS,查看两数据的行列数,果然不一样: 解决方法: 将列数多的影像按列数少的位边界提取,借助批量掩膜工具(工具箱来自ZHOU-LONG) 下载地址: >可以将存有数据的文件载入到MATLAB中,例如,所有的数据存在xls或者txt文件中,那么可以将他们直接载入到MATLAB中
Data=xlsread('dataxls');
Data=load('datatxt');
这样,所有数据将以矩阵Data存在MATLAB中了,程序直接调用矩阵Data就可以了
出现这个错误是因为你的datatxt不在你MATLAB的当前工作目录下,你可以将datatxt拖到MATLAB的工作目录下,或者在当前工作目录下新建一个。
总之是让MATLAB能找得到datatxt>> 2e-2/2e-5
ans =
10000e+003
>> 2e-2/25e-5
ans =
800
因为浮点数运算存在舍入误差
2e-2/2e-5 理论上结果是 1000
但得到的结果实际上不是精确的1000
而是1000加上一个绝对值很小的数,也就是浮点运算的误差
那么结果就不是整数,所以会报错
而2e-2/25e-5的计算结果,刚好能够取到理论值800,所以就不报错
用 zeros(round(2e-2/2e-5))先取整一下就好MATLAB图像处理工具箱支持四种基本图像类型:索引图像、灰度图像、二进制图像和RGB图像。MATLAB直接从图像文件中读取的图像为RGB图像。它存储在三维数组中。这个三维数组有三个面,依次对应于红(Red)、绿(Green)、蓝(Blue)三种颜色,而面中的数据则分别是这三种颜色的强度值,面中的元素对应于图像中的像素点。设所得矩阵为X三维矩阵(256,256,3) ,X(:,:,1)代表红颜色的2维矩阵 X(:,:,2)代表绿颜色的2维矩阵, X(:,:,3)代表兰颜色的2维矩阵。[X, map]=imread('34bmp');r=double(X(:,:,1)); %r是256 x 256的红色信息矩阵g=double(X(:,:,2)); %g是256 x 256的绿色信息矩阵b=double(X(:,:,3)); %b是256 x 256的兰色信息矩阵
索引图像数据包括图像矩阵X与颜色图数组map,其中颜色图map是按图像中颜色值进行排序后的数组。对于每个像素,图像矩阵X包含一个值,这个值就是颜色图数组map中的索引。颜色图map为m×3双精度矩阵,各行分别指定红、绿、蓝(R、G、B)单色值,map=[RGB],R、G、B为值域为[0,1]的实数值,m为索引图像包含的像素个数。
对于相同的数据,采用uint8格式比双精度格式节省内存空间,从而更经济。在MATLAB中
如果索引图像的颜色图小于256行,则它的图像矩阵以uint8格式存储,否则以双精度格式存储。
一:imread:从图像文件夹中读取图像。
A = imread(FILENAME,FMT) 读取图像到A,如果文件是包含一灰度图像,A是一二维矩阵,如果文件是包含一真彩色图像(RGB),A是一三维矩阵(M-by-N-by-3)。FILENAME :图像文件名;FMT:图像文件格式;
文件必须在当前目录下,或在Matlab的一路径上。如果 imread不能够找到一名称为FILENAME的文件,那么它将找一名为FILENAMEFMT的文件
[X,MAP] = imread(FILENAME,FMT) 把图像FILENAME读入与它相关的图像色彩信息写入MAP,图像色彩信息值在范围[0,1]中自动地重新调整
[] = imread(FILENAME)这种方式是试图得到文件的格式从文件所包含的信息。
[] = imread(URL,)从一Internet URL上读图像 URL 必须包含协议(即: ">
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)