matlab如何输出英文数字,用MATLAB打开含有英文、数字和汉字的txt文件

之前也没接触过用MATLAB打开含有英文、数字和汉字的txt文件,结果网上查了一下,打开的文件内容中文全部显示乱码,折腾了大半天终于解决了。

一、常用打开方法:

1、Data = load("filename.txt");

只支持仅含有数字的文本文件,如果夹杂着字母或者汉字,则会报错。

2、Data = importdata("filename.txt");

可以读取数字和字符:Data.data里存放纯数字,Data.textdata是以文本形式存放的所有数据。

3、textread

见高人博客http://blog.sina.com.cn/s/blog_9e67285801010bju.html

4、tline = fgetl(fid)

从文件中读取一行数据,并去掉行末的换行符。

fid是通过fopen函数打开文件后得到的一个整型的文件标识。fgetl从这个文件中读取一行数据并丢弃其中的换行符。如果读取成功,tline容纳了读取到的文本字符串,如果遇到文件末尾的结束标志(EOF),则函数返回-1,即tline值为-1。

返回的字符串tline并不包含文本行的行终止符。要得到行终止符,可以使用函数fgets。

最开始用的代码:

fid = fopen('test.txt');

while 1

tline = fgetl(fid);

if ~ischar(tline)

break

end

disp(tline)

end

fclose(fid);

但是这样中文会全部为乱码。网上有说用native2unicode函数转换一下。尝试无效

fid = fopen('test.txt');

while 1

tline = fgetl(fid);

if ~ischar(tline)

break

end

tline = native2unicode(tline);

disp(tline)

end

fclose(fid);

最终解决办法:这是因为fopen文件时,没有指定打开方式,则会以默认编码方式打开(ASCII码或二进制),但是很多txt文件不是这两种编码方式。在打开文件时指定为‘UTF-8’格式即可。

fid = fopen('test.txt','r','n','UTF-8');

while 1

tline = fgetl(fid);

if ~ischar(tline)

break

end

disp(tline)

end

fclose(fid);

另外附一个可能会有用的博客

‘解决MATLAB中文乱码’ https://blog.csdn.net/soliddream66/article/details/61414565

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值