时间:2021-05-22
先要明白Fscanf的工作原理
Fscanf在遇到\n才结束
遇到\r时就会把\r替换成0
这就有个问题,要注意自己的文本换行符是什么,在Windows下就是\r\n,在Linux,Mac下就是\n,也就是说这里有个坑,
代码在Linux和Mac下读取数据文件是正常的,在Windows下就会遇到各种行末尾有个0,网上办法用什么替换啊,用什么自定义Scan函数啊,太麻烦了,直接使用自带IDE将打开的数据文件集换行符改成LF(Linux,Mac换行符)就行了
如下图Idea
文件右下角LF点击就可以更换换行符
补充:go中的Fscanf读到0的问题
今天在使用Fscanf读矩阵的时候遇到了一个问题,发现每次遇到换行,就多读一个0的问题
func readMaze(filename string) [][]int { file, err := os.Open(filename) if err != nil { panic(err) } var row,col int fmt.Fscanf(file, "%d %d", &row, &col) maze := make([][]int, row) for i := range maze { maze[i] = make([]int, col) for j := range maze[i] { fmt.Fscanf(file,"%d",&maze[i][j]) } } return maze}分析得出这是由于windows下的格式导致的,在windows下的换行符是\r\n,所以遇到\r会读一个0进去,在linux下换行符只有\n
直接通过修改ide的格式即可,在goland的下方修改:
改成LF即为linux,这种方法我试了没成功,不知道是不是电脑的原因,可以先试一下这种方法
如果是不能避免,那就把这个0读出来,然后扔掉即可,可以在每行后面,多根一句话:
fmt.Fscanf(file,"%d")使用方法
fmt.Fscan(file,&maze[i][j])不规定格式的情况下是不会出现多读0
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在application.properties中填写中文信息,在读取该文件时会出现中文乱码问题。比如:application.properties内容:?12s
在Ubuntu系统中,在读取Windows文件的时候显示乱码,而在Windows读取正常,出现在问题的主要原因是编码的不同,下面小编就给大家介绍下Windo
codecs在读取文件时,发生错误:UnicodeDecodeError:'utf-8'codeccan'tdecodebyte0xbeinposition0:
使用go语言读取文件的各种方式整理。一次性加载到内存中//*整个文件读到内存,适用于文件较小的情况//每次读取固定字节//问题容易出现乱码,因为中文和中文符号不
SQLiteDatabase不支持直接从assets读取文件,所以要提前拷贝数据库。在读取数据库时,先在项目中建立assets文件夹用于存放外部文件,将数据库文