Fortran Coder

楼主: daydaycode
打印 上一主题 下一主题

[文件读写] fortran读取有缺失的数据问题

[复制链接]

14

帖子

2

主题

0

精华

入门

F 币
97 元
贡献
49 点
跳转到指定楼层
楼主
发表于 2020-3-24 15:52:43 | 显示全部楼层 |只看大图 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 daydaycode 于 2020-3-24 17:22 编辑

data.txt (12.64 KB, 下载次数: 3)

fortran小白请教下fortran处理txt文件问题。需要处理的数据为地面自动站气象数据,数据包含的数据类型主要有字符串和浮点及整数等类型格式,数据为62247*212的矩阵,但是在57418行到最后的前6列都没有值,这样在数据读取的时候就会提示读取文件末尾报错,请问想正确读入这类型的数据,该怎么编写fortran代码。自己参考别人的代码,写的fortran程序,不能处理以上的问题,代码及数据和报错信息如下,还请各位前辈指教下怎么修改
[Fortran] 纯文本查看 复制代码
PROGRAM predeal_dimianzidong
IMPLICIT NONE

INTEGER                                ::i,j                !读取数据的行数
INTEGER, PARAMETER      ::row=62247,col=212
CHARACTER,DIMENSION(row,col)     ::data_read,data_1

OPEN(UNIT=3, FILE='SURF_CHN_MUL_HOR_2019080100.txt', STATUS='OLD',ACTION='READ',FORM='FORMATTED',ACCESS='sequential')        !打开文件
!READ(3,*) ((data_read(i,j),j=1,col),i=1,row)
DO i = 1,row
READ(3,*)(data_read(i,j),j=1,col)
END DO
!data_1 = transpose(data_read) 
print*,SHAPE(data_read)
!PRINT*,data_1
CLOSE(UNIT=3)        !关闭文件
STOP
END PROGRAM predeal_dimianzidong


截图.png (118.2 KB, 下载次数: 447)

数据结构类型

数据结构类型

2.png (25.6 KB, 下载次数: 430)

报错情况

报错情况

4.png (59.44 KB, 下载次数: 456)

读取每行数据

读取每行数据

3.png (36.77 KB, 下载次数: 468)

读取每行数据

读取每行数据

微信截图_20200324172002.png (87.63 KB, 下载次数: 418)

缺失处截图

缺失处截图
分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

14

帖子

2

主题

0

精华

入门

F 币
97 元
贡献
49 点
沙发
 楼主| 发表于 2020-3-24 16:19:00 | 显示全部楼层
li913 发表于 2020-3-24 16:07
把你的数据上传,只需要57418行前后几行的数据就行。

DO i = 1,row

您好,数据已上传,麻烦给看一下

14

帖子

2

主题

0

精华

入门

F 币
97 元
贡献
49 点
板凳
 楼主| 发表于 2020-3-24 16:38:42 | 显示全部楼层
li913 发表于 2020-3-24 16:07
把你的数据上传,只需要57418行前后几行的数据就行。

DO i = 1,row

按照您的代码修改,还是不行,我用论坛读取非固定格式每行的数据数那个程序,发现我的数据第一行只有184个数据,还有的行没有211个数据,只有210个,像这种情况该怎么处理呢。

14

帖子

2

主题

0

精华

入门

F 币
97 元
贡献
49 点
地板
 楼主| 发表于 2020-3-24 17:21:55 | 显示全部楼层
vvt 发表于 2020-3-24 17:15
你首先需要找到一个规则。再什么情况下,你认为第一列是缺失的,什么情况下你认为是第二列缺失的?

比如: ...

这个要怎么来定呢,我也不能确定它是哪一列会有缺失,我上传了有缺失的地方截图,你可以看下。

14

帖子

2

主题

0

精华

入门

F 币
97 元
贡献
49 点
5#
 楼主| 发表于 2020-3-25 13:47:33 | 显示全部楼层
li913 发表于 2020-3-25 10:56
看起来你的文件中数据是以tab分隔的,你可以用excel打开数据,检查一下是否有误,然后另存为csv格式。读取c ...

十分感谢,现在问题解决了。请问,像这种情况只能把txt转成csv吗,还有别的方法吗?

14

帖子

2

主题

0

精华

入门

F 币
97 元
贡献
49 点
6#
 楼主| 发表于 2020-3-25 14:24:15 | 显示全部楼层
vvt 发表于 2020-3-24 17:25
你可以看看你的数据是如何得来的,是否可以转存为其他数据格式?比如 csv,用逗号间隔开。

比如

好的,多谢。

14

帖子

2

主题

0

精华

入门

F 币
97 元
贡献
49 点
7#
 楼主| 发表于 2020-3-26 10:42:14 | 显示全部楼层
li913 发表于 2020-3-25 17:50
有的,更麻烦。读取整行,以tab为分隔符,将一行分为多个记录,存入数组。 ...

好的,多谢。
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-5-2 18:53

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表