matlab 文件操作

根据数据的组织形式,Matlab 中的文件可分为ASCII 文件和二进制文件。ASCII
文件又称文本文件,它的每一个字节放一个ASCII 代码,代表一个字符。二进制文
件是把内存中的数据按其在内存中的存储形式原样输出到磁盘上存放。
Matlab 中的关于文件方面的函数和C 语言相似。
函 数 分 类 函数名 作 用
fopen 打开文件
打开和关闭文件
fclose 关闭文件
fread 读二进制文件
读写二进制文件
fwrite 写二进制文件
格式I/O fscanf 从文件中读格式数据
-305-
fprintf 写格式数据
fgetl 从文件中读行,不返回行结束符
fgets 从文件中读行,返回行结束符
sprintf 把格式数据写入字符串
读写字符串
sscanf 格式读入字符串
feof 检验是否为文件结尾
fseek 设置文件定位器
ftell 获取文件定位器
文件定位
frewind 返回到文件的开头
1.文件的打开和关闭
对文件读写之前应该“打开”该文件,在使用结束之后应“关闭”该文件。
函数fopen 用于打开文件,其调用格式为:
fid=fopen(‘filename’,’permission’)
fid 是文件标识符(file identifier),fopen 指令执行成功后就会返回一个
正的fid 值,如果fopen 指令执行失败,fid 就返回-1。
filename 是文件名。
permission 是文件允许操作的类型,可设为以下几个值:
‘r’ 只读
‘w’ 只写
‘a’ 只能追加(append)
‘r+’ 可读可写
与fopen 对应的指令为fclose,它用于关闭文件,其指令格式为:
status=fclose(fid)
如果成功关闭文件,status 返回的值就是0。
2.读写操作
i)fwrite 的指令格式
fid=fopen(‘filename’,’permission’)
fwrite(fid,要保存的数据矩阵,’精度格式’)
执行help fread 即可查到精度格式的设定。
ii)fprintf 的指令格式
fprintf(fid,’数据格式’,需要保存的数据矩阵)
例 产生10 个随机数,并保存到一个纯文本文件data1.txt 中。
clear,clc
a=rand(1,10)
fid=fopen('data1.txt','w');
fprintf(fid,'%8.4f',a);
fclose(fid);
load data1.txt
data1
iii)save 的指令格式
save filename 变量1 变量2 …
使用load filename 即可把变量1、变量2、…调出来。
如果要保存为ASCII 码,就要在后面加上-ascii
-306-
save filename 变量1 变量2 … -ascii
对于save 指令,处理大量数据存取有一个技巧非常有用,即:
save(‘filename’,’变量1’,’变量2’,…)
由于filename 是用字符串表示的,所以可以使用程序进行控制,使其每处理
完一次就存一个不同的文件名称。

clear,clc
m=1:10;
for i=1:length(m)
n=m.^2;
nf=[m',n'];
t=char(['nf',int2str(i),'=nf'])
eval(t)
save(['data',int2str(i)],['nf',int2str(i)])
end
iv)load 纯文本文件
load filename.txt
就建立了变量名为filename 的数据。
例 现有一纯文本数据文件caipao.txt,保存了山东省65 期的福利彩票中奖
号码,试对中奖号码给出一些统计,并按一定的规则产生两组彩票号码。
clc,clear
load caipiao.txt;
cp=caipiao;
for i=1:30
b(i)=length(find(cp==i));
end
[b,id]=sort(b);
mai1=sort(id(1:7)), mai2=sort(id(24:30))
fid1=fopen('cpsj.txt','w');
fprintf(fid1,'%6d %6d %6d %6d %6d %6d %6d %6d\n',caipiao');
fclose(fid1)
下载方式:https://pan.quark.cn/s/a4b39357ea24 布线问题(分支限界算法)是计算机科学和电子工程领域中一个广为人知的议题,它主要探讨如何在印刷电路板上定位两个节点间最短的连接路径。 在这一议题中,电路板被构建为一个包含 n×m 个方格的矩阵,每个方格能够被界定为可通行或不可通行,其核心任务是定位从初始点到最终点的最短路径。 分支限界算法是处理布线问题的一种常用策略。 该算法与回溯法有相似之处,但存在差异,分支限界法仅需获取满足约束条件的一个最优路径,并按照广度优先或最小成本优先的原则来探索解空间树。 树 T 被构建为子集树或排列树,在探索过程中,每个节点仅被赋予一次成为扩展节点的机会,且会一次性生成其全部子节点。 针对布线问题的解决,队列式分支限界法可以被采用。 从起始位置 a 出发,将其设定为首个扩展节点,并将与该扩展节点相邻且可通行的方格加入至活跃节点队列中,将这些方格标记为 1,即从起始方格 a 到这些方格的距离为 1。 随后,从活跃节点队列中提取队首节点作为下一个扩展节点,并将与当前扩展节点相邻且未标记的方格标记为 2,随后将这些方格存入活跃节点队列。 这一过程将持续进行,直至算法探测到目标方格 b 或活跃节点队列为空。 在实现上述算法时,必须定义一个类 Position 来表征电路板上方格的位置,其成员 row 和 col 分别指示方格所在的行和列。 在方格位置上,布线能够沿右、下、左、上四个方向展开。 这四个方向的移动分别被记为 0、1、2、3。 下述表格中,offset[i].row 和 offset[i].col(i=0,1,2,3)分别提供了沿这四个方向前进 1 步相对于当前方格的相对位移。 在 Java 编程语言中,可以使用二维数组...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值