Fortran Coder

查看: 28733|回复: 16
打印 上一主题 下一主题

[文件读写] 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)

缺失处截图

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

798

帖子

2

主题

0

精华

大宗师

F 币
3793 元
贡献
2268 点
沙发
发表于 2020-3-24 16:07:46 | 只看该作者
本帖最后由 kyra 于 2020-3-24 17:19 编辑

把你的数据上传,只需要57418行前后几行的数据就行。

[Fortran] 纯文本查看 复制代码
DO i = 1,row
if(i<57418) then
READ(3,*) data_read(i,:)
else
READ(3,*) data_read(i,7:)
end if
END DO

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个,像这种情况该怎么处理呢。

954

帖子

0

主题

0

精华

大师

F 币
184 元
贡献
75 点

规矩勋章元老勋章新人勋章水王勋章热心勋章

QQ
5#
发表于 2020-3-24 17:15:00 | 只看该作者
你首先需要找到一个规则。再什么情况下,你认为第一列是缺失的,什么情况下你认为是第二列缺失的?

比如:
姓名   年龄  体重
张三   30    55.3
李四      40
你如何判断第二行的40,是年龄还是体重?

14

帖子

2

主题

0

精华

入门

F 币
97 元
贡献
49 点
6#
 楼主| 发表于 2020-3-24 17:21:55 | 只看该作者
vvt 发表于 2020-3-24 17:15
你首先需要找到一个规则。再什么情况下,你认为第一列是缺失的,什么情况下你认为是第二列缺失的?

比如: ...

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

954

帖子

0

主题

0

精华

大师

F 币
184 元
贡献
75 点

规矩勋章元老勋章新人勋章水王勋章热心勋章

QQ
7#
发表于 2020-3-24 17:24:02 | 只看该作者
我既然回复你的帖子,肯定都认真看过你提供的所有内容了。

我没有办法判断,因为你不管说 40 是年龄,还是体重,都是不违背任何规则的。

你是问题的提出者,应该你来确定问题的规则。然后根据问题的规则来书写合适的代码。

954

帖子

0

主题

0

精华

大师

F 币
184 元
贡献
75 点

规矩勋章元老勋章新人勋章水王勋章热心勋章

QQ
8#
发表于 2020-3-24 17:25:57 | 只看该作者
你可以看看你的数据是如何得来的,是否可以转存为其他数据格式?比如 csv,用逗号间隔开。

比如
姓名  , 年龄 , 体重
张三  , 30 ,   55.3
李四   ,,   40

因为第3行有两个逗号,我可以认定,40应该是体重,而年龄缺失。

798

帖子

2

主题

0

精华

大宗师

F 币
3793 元
贡献
2268 点
9#
发表于 2020-3-25 10:56:04 | 只看该作者
看起来你的文件中数据是以tab分隔的,你可以用excel打开数据,检查一下是否有误,然后另存为csv格式。读取csv格式就方便了。
[Fortran] 纯文本查看 复制代码
program test
  implicit none
  integer i
  INTEGER, PARAMETER      ::row=11,col=212
  character(40) dat(col-6, row)
  dat = 'undefined'
  open(10,file='1.csv')
  read(10,*)
  do i = 1, row
    read(10,*) dat(:,i)
  end do
  close(10)
end program

14

帖子

2

主题

0

精华

入门

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

十分感谢,现在问题解决了。请问,像这种情况只能把txt转成csv吗,还有别的方法吗?
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

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

GMT+8, 2024-4-26 07:05

Powered by Tencent X3.4

© 2013-2024 Tencent

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