Fortran中批量处理文件的方法总结

合集下载

Fortran程序总结

Fortran程序总结

1.行的书写(行的长度、分行、续行)一行可以是0~132个字符,空格有意义,语句最长不超过2640个字符一行可以有多个语句,用“;”分隔一个语句可分行写,读行标记为&(放在尾部),但如为关键字,首尾均加&。

最多可有511个续行。

2.说明语句必须出现在可执行语句之前,格式说明语句(FORMAT语句)除外。

3.注释标志符:自由格式:!固定格式:C *语句分隔符:分号;(仅自由格式可以使用)续行符:自由格式:&申明标号:1到5位无符号整数空格:关键字、变量、常量内部不能用空格,但相邻两者之间须用空格4.信息处理的分类:数值处理和信息处理现代计算机工作原理:程序存储和程序控制(冯·诺依曼)1、运算器——算术运算、逻辑运算2、控制器——根据指令控制计算机工作运算器、控制器和寄存器称为中央处理器CPU3、I/O设备——提供数据传输服务4、总线——数据传输的公共通道1.机器语言:二进制代码形式,可以被计算机直接执行,不可移植2.汇编语言:用助记符来代替机器指令,容易记忆,不可移植3.高级语言:接近自然语言(英语)的程序设计语言,又称算法语言,易学、易用、易维护,可移植性好例:FORTRAN、BASIC、PASCAL、C、LISP、PROLOG等5.FORTRAN90程序是一种分块结构,由若干个程序单元块组成:主程序、外部子程序、模块、块数据单元无论是主程序单元,还是子程序单元,都是独立的程序单位,应该独立编写,它们的形式相似。

非语句行:注释语句:!后的所有字符都被编译器忽略。

可独占一行,也可在其它语句之后,空行为注释行(固定格式用C和*)6.常量的定义:常量是程序执行过程中不能变化的量。

基本数据类型有五种:整型、实型、复型、字符型和逻辑型前三种属于数值类型,后两种为非数值类型,主要用于文字处理和控制。

FORTRAN 90通过KIND值确定整数的存储开销、最大位数和取值范围,如表所示。

Fortran中批量处理文件方法总结

Fortran中批量处理文件方法总结

Fortran中批量处理文件的方法总结—循环读取目录下的所有符合条件的文件一、简单的介绍在一年之前,我写过一个程序,主要是对Micaps资料进行批量处理,将逐日资料处理为旬、月的数据,在那个程序中,始终有一个问题困扰我,就是如何自动生成该读取的下一个文件名,这使我真正开始关注fortran中的批处理,时隔一年,决定写下这些文字,将我用到的一些fortran批处理的方法和大家共享,交流。

对于那些只要会用程序,不求其中原理的朋友,请马上跳过这些文字,直接去下载附件吧!程序里有使用说明,但是,如果你不懂原理,估计现成的程序你使用起来也会碰壁哦!这里所说的批处理是指对某一个目录下的指定后缀的文件的批量读取和处理。

我总结的批处理方法大概可以用下面这个示意图来说明:|||将文件目录写入一个文本文件,供fortran循环读取|————手动输入文件名|————运行程序之前命令行工具导出文件名|————程序运行后,未开始计算之前,生成文件名| ————调用CMD命令生成| ————GETFILEINFOQQ方法生成| ————调用WIN32API生成||在程序运行时动态生成文件名||对于第一种方法,我将主要介绍如何将目录写入文件,然后举出一个小的示例来验证。

第二种方法主要是说明其思路。

二、方法的介绍1、将文件目录写入一个文本文件,供fortran循环读取1.1、手动输入文件名这是最基本的方法啦,如果文件个数不多,而且文件名中包含了空格等特殊字符的话,建议使用这种方法,在这里就不多说啦,至于在fortran中的处理,等几个小方法介绍完之后会有一个例子来说明。

1.2、运行程序之前命令行工具导出文件名这是一个既高效又保险的方法,主要思路就是通过强大的CMD命令列出目录下的文件到一个指定的文件中,然后由fortran去循环读取该文件中的文件名信息,从而批量处理。

a、从运行工具打开你的CMD窗口;b、转到要处理的当前目录(可省略):CD /d 路径,如:CD /d e:\test这样可以快速到达e:\test目录c、使用DIR命令列出文件目录信息到指定的文件,通常使用的Dir *.*>新文件名这个命令在这里已经不能满足要求,因为会列出一堆对于我们处理而言无用的信息,现在要使用的命令是:DIR /b filter>newfile注意,其中的filter为文件筛选,必须自己修改为所需的,比如你可以把它改成*.txt,这样,就会列出当前目录下的所有txt结尾的文件了。

Fortran进行批处理地方法

Fortran进行批处理地方法

Fortran中批量处理文件的方法总结—循环读取目录下的所有符合条件的文件=====================一、简单的介绍在一年之前,我写过一个程序,主要是对Micaps资料进行批量处理,将逐日资料处理为旬、月的数据,在那个程序中,始终有一个问题困扰我,就是如何自动生成该读取的下一个文件名,这使我真正开始关注fortran中的批处理,时隔一年,决定写下这些文字,将我用到的一些fortran批处理的方法和大家共享,交流。

对于那些只要会用程序,不求其中原理的朋友,请马上跳过这些文字,直接去下载附件吧!程序里有使用说明,但是,如果你不懂原理,估计现成的程序你使用起来也会碰壁哦!这里所说的批处理是指对某一个目录下的指定后缀的文件的批量读取和处理。

我总结的批处理方法大概可以用下面这个示意图来说明:|||将文件目录写入一个文本文件,供fortran循环读取|————手动输入文件名|————运行程序之前命令行工具导出文件名|————程序运行后,未开始计算之前,生成文件名| ————调用CMD命令生成| ————GETFILEINFOQQ方法生成| ————调用WIN32API生成||在程序运行时动态生成文件名||对于第一种方法,我将主要介绍如何将目录写入文件,然后举出一个小的示例来验证。

第二种方法主要是说明其思路。

二、方法的介绍1、将文件目录写入一个文本文件,供fortran循环读取1.1、手动输入文件名这是最基本的方法啦,如果文件个数不多,而且文件名中包含了空格等特殊字符的话,建议使用这种方法,在这里就不多说啦,至于在fortran中的处理,等几个小方法介绍完之后会有一个例子来说明。

1.2、运行程序之前命令行工具导出文件名这是一个既高效又保险的方法,主要思路就是通过强大的CMD命令列出目录下的文件到一个指定的文件中,然后由fortran去循环读取该文件中的文件名信息,从而批量处理。

a、从运行工具打开你的CMD窗口;b、转到要处理的当前目录(可省略):CD /d 路径,如:CD /d e:\test这样可以快速到达e:\test目录c、使用DIR命令列出文件目录信息到指定的文件,通常使用的Dir *.*>新文件名这个命令在这里已经不能满足要求,因为会列出一堆对于我们处理而言无用的信息,现在要使用的命令是:DIR /b filter>newfile注意,其中的filter为文件筛选,必须自己修改为所需的,比如你可以把它改成*.txt,这样,就会列出当前目录下的所有txt结尾的文件了。

fortranwrite用法 -回复

fortranwrite用法 -回复

fortranwrite用法-回复如何正确使用Fortran编程语言中的"fortranwrite"函数。

Fortran是一种广泛应用于科学计算领域的编程语言,它的特点之一就是对于数据的读写处理非常方便。

而"fortranwrite"函数作为Fortran语言中用于写入数据到文件的函数之一,具有其独特的用法和特点。

1.引言Fortran语言中的"fortranwrite"函数可用于将数据写入文件或输出设备。

通过将数据写入文件,我们可以轻松地将计算结果保存并进行后续分析。

在本篇文章中,我们将详细讨论"fortranwrite"函数的用法及相关注意事项,以帮助读者更好地理解并正确使用该函数。

2.基本用法Fortran语言在许多方面都具有简洁而不失灵活的特点,"fortranwrite"函数的使用也不例外。

下面是一些"fortranwrite"函数的基本用法:WRITE(unit, format) var1, var2, ...其中,"unit"参数表示输出单元,可以是一个文件名或其它合法的输出设备,例如控制台;"format"参数表示数据的格式,可以是一个预定义的格式字符串或一个用户自定义的格式化语句;"var1, var2, ..."是需要写入的变量。

3.数据格式化数据格式化在数据的输出和处理中至关重要。

在Fortran语言中,"format"参数用于指定数据的格式。

Fortran提供了一种方便的方式来格式化数据输出。

例如,我们可以使用以下语句将一个整数和一个实数写入文件:WRITE(unit, '(I4, F8.2)') int_var, real_var上述代码中,"I4"表示输出一个宽度为4的整数,"F8.2"表示输出一个宽度为8的实数,其中小数点后保留两位小数。

fortran用法总结

fortran用法总结

我的Fortran基本用法小结周日, 10/14/2007 - 21:00 — gator一、说明二、概述三、数据类型及基本输入输出四、流程控制五、循环六、数组七、函数八、文件一、说明本文多数内容是我读彭国伦《Fortran 95 程序设计》的笔记。

只读到第九章,主要是3~9章,都是最基本的用法(原书共16章)。

这里主要摘录了我看书过程中总结的一些Fortran和C不同的地方,主要是语法方面。

希望这份笔记能够给学过C但没有接触过Fortran的同学带去一些帮助。

要想得更清楚些,推荐看一下原书,觉得作者真的写得很好,很清楚;如果有C语言的基础,看完前九应该很快的,花一两天就行了。

觉得如果耐心看完本文,基本功能应该也可以顺利用起来了。

外,由于我之前没有用过Fortran,这次为了赶文档看书又看得很粗浅,大多数东西看过之后都没得及仔细想,只是按着作者的意思去理解。

所以这份笔记还处于纸上谈兵的层次。

如果有不妥的方,希望大家指正。

谢谢!文中蓝色的部分是程序代码,!后面的内容为注释。

二、概述1、名词解释Fortran=For mula Tran slator/Translation一看就知道有什么特色了:可以把接近数学语言的文本翻译成机械语言。

的确,从一开始,IBM设计的时候就是为了方便数值计算和科学数据处理。

设计强大的数组操作就是为了实现这一目标。

ortran奠定了高级语言发展的基础。

现在Fortran在科研和机械方面应用很广。

2、Fortran的主要版本及差别按其发展历史,Fortran编译器的版本其实很多。

现在在广泛使用的是Fortran 77和Fortran90。

ortran 90在Fortran 77基础上添加了不少使用的功能,并且改良了77编程的版面格式,所以编程时推荐使用90。

鉴于很多现成的程序只有77版本,有必要知道77的一些基本常识,至少保证能够看77程序。

以下是77和90的一些格式上的区别。

Fortran学习总结 我不是企鹅的日志 网易博客

Fortran学习总结  我不是企鹅的日志  网易博客

Fortran学习总结我不是企鹅的日志网易博客fortran学习总结-我不是企鹅的日志-网易博客FORTRAN学习总结-我不是企鹅日志-网易博客fortran学习总结目录:一、说明二、概述三、数据类型和基本输入输出4。

过程控制5。

第六周期。

阵列7。

功能8。

文件1。

描述本文多数内容是读彭国伦《fortran95程序设计》的笔记。

二、概述1、名词解释fortran=公式翻译/翻译一看就知道有什么特色了:可以把接近数学语言的文本翻译成机械语言。

的确,从一开始,ibm设计的时候就是为了方便数值计算和科学数据处理。

设计强大的数组操作就是为了实现这一目标。

fortran奠定了高级语言发展的基础。

现在FORTRAN广泛应用于科学研究和机械领域。

2.FORTRAN的主要版本和差异按其发展历史,fortran编译器的版本其实很多。

现在在广泛使用的是fortran77和fortran90。

ortran90在fortran77基础上添加了不少使用的功能,并且改良了77编程的版面格式,所以编程时推荐使用90。

鉴于很多现成的程序只有77版本,有必要知道77的一些基本常识,至少保证能够看77程序。

以下是77和90的一些格式上的区别。

fortran77:固定格式(fixedformat),程序代码扩展名:.f或.for(1)若某行以c,c 或*开头,则该行被当成注释;(2)每行前六个字符不能写程序代码,可空着,或者1~5字符以数字表明行代码(用作格式化输入出等);7~72为程序代码编写区;73往后被忽略;(3)如果太长,你可以继续排队。

续行的第六个字符必须是除\以外的任何字符。

fortran90:自由格式(freeformat),扩展名:.f90(1)以\引导注释;(2)每行可包含132个字符,行号放在每行的前面;(3)用&继续这一行,并把它放在这一行的末尾或开头。

下面是对Fortran 90的讨论。

3、fortran的一些特点,和c的一些不同事实上,有很多,当提到下面的具体方面时可以看到。

fortran 90 文件(文件的操作语句)解析

fortran 90 文件(文件的操作语句)解析

土木学院
这是已被打开 的数据文件的 内容
土木学院
土木学院
$
10
100 202
U1=2 Open(Unit=2,File='F2.DAT',Status='New', Access='Sequential',Form='Formatted') do 10 I=1,30 write(*,*) "请输入学号、两门成绩" Read(*,*) N,A,B C=A+B Write(2,202) '学号:', N,'总成绩',C continue 输入30个学生的学号 Close(2) 和两门成绩,最后将总 Format(I2,F5.1,F5.1) 成绩与学号输出来. Format(A,I2,A,F7.1) End
我们现在主要以磁盘设备为例来介绍FORTRAN 对文件操作的语句(打开、关闭、定位、输入和输出)
土木学院
FORTRAN的数据文件由记录组成,也就是对文 件的存取是以记录为单位进行的;
文件
记录:长度不超过规定范围的数字或文本 的集合;
记录
Fortran的数据文件按存取方式可划分为: 1. 顺序存取文件(顺序文件) 其存取操作必须从头到尾顺序进行; 2. 直接存取文件(直接文件或随机文件) 在程序的执行过程中对任意一个指定的 记录进行操作(读和写)。
Access=SD 代表文件的存取方式: Direct:以直接方式存取;Sequential: 以顺序方式存取;
Form=fe 代表文件存放格式:Formatted-字符形式
在Open中省略Access和Form,则表示打开文件为 有格式顺序存取文件.

VBA与文件批量操作技巧

VBA与文件批量操作技巧

VBA与文件批量操作技巧VBA(Visual Basic for Applications)是一种广泛应用于Microsoft Office应用程序中的编程语言,可以用于自动化任务、增强功能和提高办公效率。

在处理大量文件时,VBA可以成为一个强大的工具,帮助我们进行文件的批量操作,从而节省时间和努力。

本文将介绍一些VBA与文件批量操作的技巧,帮助您更高效地处理大量文件。

1. 批量重命名文件在处理大量文件时,有时需要统一修改文件的命名格式。

利用VBA,我们可以轻松实现这一操作。

首先,我们需要遍历文件夹中的所有文件,并逐个重命名。

例如,如果我们想将文件名前缀改为"New_",可以使用如下的VBA代码:```vbaSub BatchRenameFiles()Dim MyFile As ObjectDim MyPath As StringDim NewName As StringMyPath = "C:\YourFolderPath\" '替换为文件所在文件夹的路径NewName = "New_" '替换为新的文件名前缀Set MyFile = CreateObject("Scripting.FileSystemObject") MyFile = MyFile.GetFolder(MyPath).FilesFor Each File In MyFileName File As MyPath & NewName & Next FileEnd Sub```将上述代码中的"C:\YourFolderPath\"替换为实际文件所在的文件夹路径,并将"New_"替换为要添加的前缀。

运行该代码,所有文件名前面都将添加上指定的前缀。

2. 批量复制文件有时,我们需要将一个文件夹中的所有文件复制到另一个文件夹中。

Fortran 批量处理文件

Fortran 批量处理文件

Fortran 批量处理文件程序中需要读取或处理大量文件的时候,在代码中写入大量的open语句就显得很笨重,如果文件很多(比如有1000个文件),这种方法根本不可行。

针对这种情况,介绍两种解决方法。

方法一:考虑如下情形:假设存在100个文件,分别存储了1900-1999年的降雨量,现在需要计算着100年的总降雨量。

文件名为:前缀+年份+后缀,例如:降雨量-1900.dat、降雨量-1901.dat 。

由于文件名是有规律的,仅年份变化,可以用循环来一次读取文件。

program testinteger ireal s, acharacter(20):: filename='降雨量-1234.dat's = 0.0do i=1900, 1999!内部文件读写,将filename第8-11字符换为相应年份write(filename(8:11),'(i4)') iopen(11,file=filename)read(11,*) aclose(11)s = s + aend doend program这种方法优点是可以按顺序读取文件,缺陷也很明显,只能处理有规律的文件名。

方法二:如果文件名没有规律,使用另一种方法。

先用命令行指令将需要处理的文件的文件名写入另外一个文件当中:call system ('dir *.txt /b > 1.dat' )上述代码含义:找出工作目录下所有txt文件,将其文件名存入1.dat当中,注意二者的后缀不应相同(txt, dat)。

为了避免错误,需要事先删除无用的txt文件。

修改命令行指令,可以找出任意符合条件的文件,比如找出上例中存储降雨量的文件:call system ('dir 降雨量-*.dat /b > 1.txt' )完整代码如下:program testinteger ireal s, acharacter(512):: filename!文件1.dat中存储工作目录下所有txt文件列表call system ('dir *.txt /b > 1.dat' )s = 0.0open(10,file='1.dat')do!读取文件名read(10,'(a)',iostat=i) filenameif(i/=0) exitopen(11,file=filename)read(11,*) aclose(11)s = s + aend doclose(10,status='delete') !关闭并删除文件1.datend program方法二优点是不要求文件名称有很强规律性,缺点是处理每个文件的顺序是未知的。

fortran文件知识点

fortran文件知识点

Fortran文件知识点Fortran(Formula Translation)是一种高级编程语言,专门用于科学和工程计算。

它于20世纪50年代初由IBM公司开发,并成为第一种被广泛应用的程序设计语言。

Fortran文件是指使用Fortran语言编写的源代码文件,其中包含了Fortran程序的逻辑和算法。

在本文中,我们将逐步介绍Fortran文件的知识点,帮助读者了解如何编写和使用这种文件。

第一步:文件结构Fortran文件通常由以下几个部分组成:1.程序声明:用于声明程序的名称和目的,以及引入外部模块或库文件。

2.变量声明:用于声明程序中使用的各种变量,包括整数、实数、字符等类型。

3.主程序:包含实际的计算逻辑和算法,用于执行特定的任务或解决问题。

第二步:文件扩展名Fortran文件通常使用.f或.f90作为文件扩展名。

.f扩展名是Fortran 77的标准,而.f90扩展名是Fortran 90及更高版本的标准。

这些扩展名有助于编译器识别文件类型并选择正确的编译方式。

第三步:编写Fortran文件编写Fortran文件可以使用任何文本编辑器,例如记事本、Sublime Text、Visual Studio Code等。

以下是一个简单的Fortran文件示例:program helloimplicit nonecharacter(10):: namewrite(*,*)'请输入您的名字:'read(*,*) namewrite(*,*)'您好,', trim(name), '!'stopend program hello在这个示例中,我们定义了一个名为hello的主程序,其中包含一个字符类型的变量name。

程序首先向用户请求输入姓名,然后输出一个问候语。

最后,程序通过stop语句终止运行。

第四步:编译和运行Fortran文件要编译Fortran文件,我们需要使用特定的编译器。

Fortran基本用法小结

Fortran基本用法小结

2、Fortran的主要版本及差别
按其发展历史,Fortran编译器的版本其实很多。现在在广泛使用的是Fortran77和Fortr
an90。 Fortran90在Fortran77基础上添加了不少使用的功能,并且改良了77编程的版面格式,
所以编程 时推荐使用90。鉴于很多现成的程序只有77版本,有必要知道77的一些基本常识,至少保
program main
!程序开始,main是program的名字,完全自定义
write(*,*)"Hello" !主程序
stop
!终止程序
end[program[main]] !end用于封装代码,表示代码编写完毕。
[]中的内容可省略,下同。
再看一段实用一些的程序,好有点感性认识。程序用于计算圆柱的表面积,要求输入底面
一、说明
本文多数内容是我读彭国伦《Fortran95程序设计》的笔记。只读到第九章,主要是3~9
章,都是 些最基本的用法(原书共16章)。这里主要摘录了我看书过程中总结的一些Fortran和C不
/?uid-1039-action-viewspace-itemid-16895
/?uid-1039-action-viewspace-itemid-16895
4/9
13-4-13
[转载] Fortran基本用法小结 - 朱文举的给排水专业博客 - 国科社区-国家科技成果网 - Powered by X-Space
interactive_loop: do
/?uid-1039-action-viewspace-itemid-16895
6/9
13-4-13
[转载] Fortran基本用法小结 - 朱文举的给排水专业博客 - 国科社区-国家科技成果网 - Powered by X-Space

fortran用法小结

fortran用法小结

Fortran用法小结目录:一、说明二、概述三、数据类型及基本输入输出四、流程控制五、循环六、数组七、函数八、文件一、说明本文多数内容是我读彭国伦《Fortran 95 程序设计》的笔记。

只读到第九章,主要是3~9 章,都是最基本的用法(原书共16章)。

这里主要摘录了我看书过程中总结的一些Fortran 和C不同的地方,主要是语法方面。

希望这份笔记能够给学过C但没有接触过Fortran的同学带去一些帮助。

要想得更清楚些,推荐看一下原书,觉得作者真的写得很好,很清楚;如果有C语言的基础,看完前九应该很快的,花一两天就行了。

觉得如果耐心看完本文,基本功能应该也可以顺利用起来了。

外,由于我之前没有用过Fortran,这次为了赶文档看书又看得很粗浅,大多数东西看过之后都没得及仔细想,只是按着作者的意思去理解。

所以这份笔记还处于纸上谈兵的层次。

如果有不妥的方,希望大家指正。

谢谢!文中蓝色的部分是程序代码,!后面的内容为注释。

二、概述1、名词解释Fortran=Formula Translator/Translation一看就知道有什么特色了:可以把接近数学语言的文本翻译成机械语言。

的确,从一开始,IBM设计的时候就是为了方便数值计算和科学数据处理。

设计强大的数组操作就是为了实现这一目标。

Fortran奠定了高级语言发展的基础。

现在Fortran在科研和机械方面应用很广。

2、Fortran的主要版本及差别按其发展历史,Fortran编译器的版本其实很多。

现在在广泛使用的是Fortran 77和Fortr an90。

Fortran 90在Fortran 77基础上添加了不少使用的功能,并且改良了77编程的版面格式,所以编程时推荐使用90。

鉴于很多现成的程序只有77版本,有必要知道77的一些基本常识,至少保证能够看77程序。

以下是77和90的一些格式上的区别。

Fortran 77:固定格式(fixed format),程序代码扩展名:.f或.for(1)若某行以C,c或*开头,则该行被当成注释;(2)每行前六个字符不能写程序代码,可空着,或者1~5字符以数字表明行代码(用作格式化输入出等);7~72为程序代码编写区;73往后被忽略;(3)太长的话可以续行,所续行的第六个字符必须是"0"以外的任何字符。

(完整版)fortran文件操作

(完整版)fortran文件操作

fortran文件操作From: 《Fortran 95 程序设计》彭国伦1.文件读取的概念:读取:“顺序读取”和“直接读取”。

保存:“文本文件”和“二进制文件”。

二进制文件:读取快,因为保存格式和数据在内存中的保存方法一样,同时也节省空间。

----------------------------------2. 文件的操作:----------------------------------open的使用:使用open命令打开文件之后,就可以对文件来做输入输出。

example:program ex0901impicit noneopen(unit=10, file='hello.txt') ! 打开hello.txt文件, unit指定文件代码,file 指定文件名称。

write(10, *) "hello" !在代码为10的文件中写入hellostopend program ex0901open中有很多参数可以使用,详细如下:OPEN(UNIT=number, FILE='filename', FORM='...', STATUS='...', ACCESS='...', RECL=length, ERR=label, IOSTAT=iostat, BLANK='...', POSITION='...', ACTION=action, PAD='...', DELIM='...')UNIT='number': number必须是一个正整数,它可以使用变量或是常量来赋值。

number最好避开1,2,5,6。

因为2,6是默认的输出位置,也就是屏幕。

1,5则是默认的输入位置,键盘。

FILE='filename':指定要打开的文件名称,文件名要符合系统规定。

fortran程序文件的使用

fortran程序文件的使用

前文件指针位置向后回退一个记录位置。使用 BACKSPACE语句完成文件指针回退操作。
一般格式:
BACKSPACE{<设备号>∣ ([Unit=]< 设备号>∣ERR=<错误转移>∣IOSTAT=&端、打印机、串行口、并行口等设备。
象使用外部文件一样使用这些外部设备。每一个外部设备都有一个
一般格式:
OPEN([UNIT=]<设备号>,FILE=<文件名>[,ACCESS=<存取方式>]
[,FORM=<存储格式>][,RECL=<记录长度>][,ERR=<错误转移>] [,BLOCKSIZE=<缓冲区大小>][,CARRIAGECONTROL=<首字符含义 >] [,DELIM=<分界符>][,BLANK=<空格含义>][,ACTION=<读写方式 >]
有格式顺序文件读写操作与键盘、显示器的读写
操作类似,不同的是需要用OPEN语句打开文件,指 定设备号,在READ和WRITE语句中指定设备号,而不 是星号“*”。
PROGRAM chaper1271 INTEGER :: A(10),sum=0,ave !打开一数据文件,先用文本编辑器创建,默认是一个有格式顺序存取文件 !数据文件中有10个整数,第1行5个,第2行2个,第3行3个 !数据文件有3个记录行,每个记录行长度不同 OPEN(11,FILE='input1.dat') READ(11,*)(A(I),I=1,10) !按表控格式从数据文件中输入10个数 !READ(11,*) A(1),A(2),A(3),A(4),A(5) !可用3个READ语句分3个行输入 !READ(11,*) A(6),A(7) !READ(11,*) A(8),A(9),A(10) CLOSE(11) DO I=1,10 sum=sum+A(I) ENDDO ave=sum/10 !打开一个最大记录长度为25的有格式顺序存取文件 OPEN(12,FILE='input2.dat',RECL=25) WRITE(12,"('10个数之和为:',I5)") sum !输出一个记录行,记录长度为19 WRITE(12,“(„10个数平均值为:',I5)") ave !输出一记录行,记录长度为21 WRITE(*,*) '程序运行正常结束。' END

fortran语言知识点总结

fortran语言知识点总结

fortran语言知识点总结Fortran语言知识点总结:1. 基本语法和数据类型Fortran的基本语法和数据类型与其他编程语言类似,包括变量声明、赋值、条件语句、循环语句等。

在Fortran中,变量可以使用不同的数据类型进行声明,包括整数、实数、逻辑型和字符串型。

此外,Fortran还支持数组类型,可以方便地处理多维数组数据。

2. 过程和函数Fortran支持模块化编程,可以将代码模块化为过程和函数。

过程是一系列执行指令的代码块,可以在程序中被多次调用。

函数是一个具有返回值的过程,可以被其他代码调用,并返回一个值。

通过过程和函数的使用,可以提高代码的重用性和可维护性。

3. 指针和动态内存分配Fortran支持指针和动态内存分配,可以在程序中灵活地操作内存。

通过指针,可以获得变量的地址,并在程序中直接操作内存。

同时,动态内存分配允许程序在运行时分配或释放内存,可用于处理不确定大小的数据。

4. 文件操作Fortran提供了丰富的文件操作功能,可以进行文件的打开、写入、读取和关闭等操作。

通过文件操作,可以将程序的输入和输出与外部文件进行交互,从而扩展程序的功能和应用范围。

5. 并行计算Fortran具有强大的并行计算能力,可以利用多核处理器和分布式计算环境实现并行计算。

通过并行计算,可以加速程序的执行速度,提高计算效率。

6. 编译和调试Fortran程序需要通过编译器进行编译,生成可执行文件。

Fortran编译器通常会检查程序的语法和语义错误,并生成可执行文件。

同时,Fortran还提供了丰富的调试工具,可以帮助程序员发现和修复程序中的错误。

7. 数值计算和科学工程计算Fortran是一种专门用于数值计算和科学工程计算的语言,提供了丰富的数学库和科学计算库。

通过这些库,可以方便地进行复杂的数值计算和科学工程计算。

总结:Fortran是一种专门用于数值计算和科学工程计算的编程语言,具有丰富的数学库和科学计算库。

Fortran写txt文件,每行输出个数不确定时

Fortran写txt文件,每行输出个数不确定时

在Fortran中有的时候要输出一个二维或三维数组,比如流速等。

这个时候我们希望每一行能够写入多个数据。

加入我们有二维流场u(i,j). i=1,imax. j=1,jmax. 输出的时候我们希望文件中每一行输出u中的每一行或每一列。

一般情况下,我们可以用write(fid,'(10f12.6)', u(i,:)这种方法输出。

但这个是数字10,必须是已知的。

因为write里面的fmt部分,不允许用变量名。

比如不能写成write(fid,'(jmaxf12.6)', u(i,:).有的编译器支持write(fid,'(<jmax>f12.6)', u(i,:)的写法。

但通用的解决办法就是先将数字写成string,然后拼接成我们需要的fmt格式。

例子如下:Program test_writeImplicit noneinteger :: i,j, imax,jmaxcharacter(50) :: xstringreal(kind=8),dimension(:,:), allocatable :: u! u为流场,先定义它的大小,imax,jmaximax = 100;jmax = 10;allocate(u(imax,jmax)) !分配空间! Define the array u,这里随意给了几个值do i=1,100do j=1,10u(i,j) = i+jenddoenddo! Open the file to output,分四种情况,对比输出结果open(11,file='test_output1.txt')open(12,file='test_output2.txt')open(13,file='test_output3.txt')open(14,file='test_output4.txt')open(15,file='test_output5.txt')open(16,file='test_output6.txt')!Method 1: Two loops! 循环两次,每次输出u(i,j), 输出结果是一竖列的值,do i = 1, imaxdo j= 1, jmaxwrite(11,'(f12.6)') u(i,j)enddoenddo!Method 2: inner loop!输出的时候,循环可以写到write这句里面do i = 1, imaxwrite(12,'(f12.6)') (u(i,j),j=1,jmax)enddo!Method 3: Already know the size of the array!如果已知每行要输出的个数,可按如下输出,每行10个do i = 1, imaxwrite(13,'(10f12.6)') (u(i,j),j=1,jmax)enddo!Method 4: The size of the array varies!当事先不知道每行要输出多少个,或者说数组大小会一直变,又不想每次都去更改程序的输出语句的时候,利用下面的方法do i = 1, imaxwrite (xstring,1000) jmax !把数字转换为字符串1000 format(I3)xstring = '('//trim(ADJUSTL(xstring))//'f12.6)' !拼接为要求的format格式xstring = TRIM(ADJUSTL(xstring))write(14,xstring) (u(i,j),j=1,jmax) !利用此格式输出。

fortran获取文件行数和列数的程序

fortran获取文件行数和列数的程序

一、概述Fortran是一种用于科学计算和工程计算的高级编程语言,广泛应用于数值模拟、数据分析和科学计算等领域。

在Fortran中,获取文件的行数和列数是一个常见的需求,特别是在处理大量数据时。

本文将介绍如何在Fortran中编写程序来获取文件的行数和列数。

二、获取文件行数的程序在Fortran中,我们可以使用以下程序来获取文件的行数:```program count_linesimplicit nonecharacter(len=100) :: filenameinteger :: num_lines, unit_num, ios! 获取文件名print*, "请输入文件名:"read(*, '(A)') filename! 打开文件open(unit=unit_num, file=trim(filename), status='old', action='read', iostat=ios)if (ios /= 0) thenprint*, "错误:无法打开文件"stopendif! 循环读取文件行数num_lines = 0doread(unit_num, '(A)', iostat=ios)if (ios /= 0) exitnum_lines = num_lines + 1end do! 关闭文件close(unit_num)! 输出结果print*, "文件", trim(filename), "共有", num_lines, "行"end program count_lines```以上程序首先提示用户输入文件名,然后打开文件并循环读取文件行数,直到读取完整个文件。

最后输出文件的行数。

三、获取文件列数的程序在Fortran中,我们可以使用以下程序来获取文件的列数:```program count_columnsimplicit nonecharacter(len=100) :: filenameinteger :: num_columns, unit_num, ioscharacter(len=100) :: line! 获取文件名print*, "请输入文件名:"read(*, '(A)') filename! 打开文件open(unit=unit_num, file=trim(filename), status='old', action='read', iostat=ios)if (ios /= 0) thenprint*, "错误:无法打开文件"stopendif! 读取第一行read(unit_num, '(A)', iostat=ios) linenum_columns = 0! 循环读取每个字符do while (ios == 0)num_columns = num_columns + 1read(line, '(A)', iostat=ios) lineend do! 关闭文件close(unit_num)! 输出结果print*, "文件", trim(filename), "共有", num_columns, "列" end program count_columns```以上程序首先提示用户输入文件名,然后打开文件并读取第一行,循环读取每个字符直到读取完整个文件。

(最新整理)fortran90文件(文件的操作语句)解析

(最新整理)fortran90文件(文件的操作语句)解析

$ Access=‘Direct’,Form=‘Formatted’,Recl=16的)长度是相等的,但真正写
Do 10 I=1,N
到文件中的实际字节的个数
Write(12,100,Rec=I) I,Sqrt(Real(I))
可以比说明的长度短。
10 Continue
记录号:是不可少的参
100 Format(I3, E13.6) 数,文件的第一个记录

Read(*,*) N,A,B

C=A+B

Write(2,202) '学号:', N,'总成绩',C
• 10 continue

Close(2)
• 100 Format(I2,F5.1,F5.1)
• 202 Format(A,I2,A,F7.1)
输入30个学生的学号 和两门成绩,最后将总 成绩与学号输出来.
• 也可以使用表控输入输出语句对文件进行 格式输入输出,如:WRITE(3,*) N,M。
Next
2021/7/26
土木学院
13.2 有格式直接存取文件
• 直接存取可以任意确定需要读写记录的位 置;
• 直接存取只适用于磁盘文件;
• 其基本的操作与顺序存取大致相同,主要不 同的是:Open的说明、Read和Write的控制 项不同。
2021/7/26
土木学院
2021/7/26
土木学院
13.1有格式顺序存取文件
• 下面我们就介绍如何从文件中获得数据: (例如:从文件F1.DAT中读取数据,经过处理 后,将结果保存在F2.DAT中) 1. 准备数据文件(可以在各种编辑器中完成, 输入格式及宽度与程序要求的一致),数据文 件名的后缀为 *.DAT(也可以是*.txt); 2. 编写数据输入和数据处理文件,最后将结 果输出到F2.DAT中.
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Fortran中批量处理文件的方法总结—循环读取目录下的所有符合条件的文件一、简单的介绍在一年之前,我写过一个程序,主要是对Micaps资料进行批量处理,将逐日资料处理为旬、月的数据,在那个程序中,始终有一个问题困扰我,就是如何自动生成该读取的下一个文件名,这使我真正开始关注fortran中的批处理,时隔一年,决定写下这些文字,将我用到的一些fortran批处理的方法和大家共享,交流。

对于那些只要会用程序,不求其中原理的朋友,请马上跳过这些文字,直接去下载附件吧!程序里有使用说明,但是,如果你不懂原理,估计现成的程序你使用起来也会碰壁哦!这里所说的批处理是指对某一个目录下的指定后缀的文件的批量读取和处理。

我总结的批处理方法大概可以用下面这个示意图来说明:|||将文件目录写入一个文本文件,供fortran循环读取|————手动输入文件名|————运行程序之前命令行工具导出文件名|————程序运行后,未开始计算之前,生成文件名| ————调用CMD命令生成| ————GETFILEINFOQQ方法生成| ————调用WIN32API生成||在程序运行时动态生成文件名||对于第一种方法,我将主要介绍如何将目录写入文件,然后举出一个小的示例来验证。

第二种方法主要是说明其思路。

二、方法的介绍1、将文件目录写入一个文本文件,供fortran循环读取1.1、手动输入文件名这是最基本的方法啦,如果文件个数不多,而且文件名中包含了空格等特殊字符的话,建议使用这种方法,在这里就不多说啦,至于在fortran中的处理,等几个小方法介绍完之后会有一个例子来说明。

1.2、运行程序之前命令行工具导出文件名这是一个既高效又保险的方法,主要思路就是通过强大的CMD命令列出目录下的文件到一个指定的文件中,然后由fortran去循环读取该文件中的文件名信息,从而批量处理。

a、从运行工具打开你的CMD窗口;b、转到要处理的当前目录(可省略):CD /d 路径,如:CD /d e:\test这样可以快速到达e:\test目录c、使用DIR命令列出文件目录信息到指定的文件,通常使用的Dir *.*>新文件名这个命令在这里已经不能满足要求,因为会列出一堆对于我们处理而言无用的信息,现在要使用的命令是:DIR /b filter>newfile注意,其中的filter为文件筛选,必须自己修改为所需的,比如你可以把它改成*.txt,这样,就会列出当前目录下的所有txt结尾的文件了。

Newfile就是你需要存放文件名的那个文件,比如可以是 dir.txt,这样就成了 dir /b*.txt>dir.txt,就会把当前目录下的所有文件都列出到dir.txt文件中,当然,由于dir.txt也在当前目录,所以也会被算进去,这在处理的时候是需要注意的,下面几种方法中同样考虑了这个问题。

你可以选择手动删掉,或者把dir.txt这个文件存到其他地方去,或者,不要和你需要的文件具有相同的后缀也行,比如:dir /b *.txt>e:\dir.txt (假设当前目录是e:\test)如果省略了第二步中的转到当前目录的话,就需要在dir命令后输入完整的路径了,而且新生成的文件也要选择有权限建立新文件的地方存放,比如你在c:\users目录下输入:dir /b e:\test\*.txt>e:\dir.txt,这个命令和上面先转到e:\test目录下的效果是一样的。

现在你是不是比较好奇,/b 是干嘛的,其实就是只列出文件名,不要其他的附件信息,比如创建时间,文件大小等等这些对于我们批处理无关的信息。

如果你想包含某个目录下的子目录,那么,就可以这样写:Dir /b/s filter>newfile/s就表示包含子目录,但是,这样会有一个问题,那就是,批处理的时候必须获得正确的路径才能操作,这样得到的子目录里面的文件不会有任何标志说他是来自子目录的,因此fortran处理的时候就无法判断了,所以,如果包含了子目录,那么请用下面的命令:Dir /a-d/b/s filter>newfile现在去看看新生成的文件吧,怎么样,很惊喜吧!懂了这个方法,下面一部分的第一个方法对你来说就是小菜一碟啦。

如果你使用的win7(或vista)系统,而且无法正常使用CVF编译器的话,那么第一部分到这里就算结束啦,除非,你会在其他fortran编译器中调用WIN32API。

1.3、程序运行后,未开始计算之前生成文件名1.3.1、在程序中调用CMD命令这个方法其实就是上一个方法的进化版,只不过变成了在程序运行的时候调用命令自动生成,这样整个过程显得少一点,只需要在程序里设置好相关的参数即可。

这个方法的关键在于SYSTEMQQ函数的使用,这是CVF编译器封装的调用CMD命令的一个函数,存在于DFLIB库中,其语法命令为:result = SYSTEMQQ(commandline)commandline:表示需要进行的CMD操作,字符串形式,函数中的实际长度由传入的参数决定,input类型(表示输入为参数);Results:一个逻辑型变量(logical(4)),如果成功为true,失败为false (不解的是程序中要实现的东西都是正常的,比如仅仅传入dir命令,返回的结果仍然为F,请高手赐教)给出一个简单的例子:USE DFLIBLOGICAL(4)resultresult = SYSTEMQQ('copy e:\dir.txt e:\test\dir.txt')这个命令将第一个路径中的文件复制到为第二个路径中的文件。

通过这个例子再结合上面一个方法,就可以很方法便的构造出我们需要用来批处理的子函数,关键语句如下所示:subroutine ListToFile(fPath,outPut)character*(*),InTent(In):: fPath,outPutcharacter*100CMDLOGICAL(4) resCMD="dir/a-d/b/s "//trim(fPath)//" >"//trim(outPut)res=SYSTEMQQ(CMD)endsubroutine其中传入的是文件筛选值和输出的路径,这个方法也是我在第一部分中最为推荐的一个方法了,代码简洁高效,能够输出完整的路径,可以包含子文件夹,唯一的缺点就是输出的文件个数不能直接在程序中调用(方便循环),需要在批处理的时候使用其他方法来判断文件是否读取结束。

NEW:{如果你使用的是WIN7系统,那么请使用上面提示下载的msf4.0版的fortran,只要把上面的子程序替换为下面所示的即可:subroutine ListToFile(fPath,outPut)character*(*),InTent(In):: fPath,outPutcharacter*100 CMDCMD="dir /a-d/b/s "//trim(fPath)//" >"//trim(outPut)call SYSTEM(CMD)endsubroutine}1.3.2、使用GETFILEINFOQQ方法生成文件目录该方法是下面一个方法的进化版,是由CVF对WIN32的API进行了封装,这样,我们就可以通过简单的调用函数来实现一些面向对象的功能。

简单的翻译了一下官方给出的GETFILEINFOQQ函数信息:Module: USE DFLIB (存在于DFLIB库中)语法简介:Syntax result = GETFILEINFOQQ (files, buffer, handle) files :输入类型的字符型变量,表示你需要查找的路径(也就是我们上面方法中的筛选值),同样可以使用*或者?这样的通配符。

buffer :在函数运行中会获得一个值,可供输出使用,这个值就是所找到的文件的相关信息,属于FILE$INFO类型的变量(该类型定义于:fortran安装路径DF98\INCLUDE路径下),其结构如下:TYPE FILE$INFO INTEGER(4)CREATION INTEGER(4)LASTWRITE INTEGER(4)LAS TACCESS INTEGER(4)LENGTH INTEGER(4)PERMIT CHARACTER(255)NAME END TYPE FILE$INFOhandle :接受输入和输出整型变量,表示文件控制信息(同样在DFLIB中定义),包含以下内容:FILE$FIRST - First matching file found. FILE$LAST - Previous file was the last valid file. FILE$ERROR - No matching file found. Results: 返回值是一个整型变量(integer(4)),表示的不含空格的文件名长度,如果文件未找到,则返回0。

了解了以上信息,我们就可以通过编程进行循环调用这个函数,每找到一个符合条件的文件,就把他输入到指定路径的文件中去,注意,凡是input类型的变量都必须传入数值,否则会出错。

如果你比较有探索精神,就试着用这个介绍和思路来编程一下吧,子程序如下所示(完整的请下载附件)SubroutineGetFileList(cFileName,outPut,iFile) UseDFLib,only:GetFileInfoQQ,GetLas tErrorQQ,FILE$INFO,FILE$LAST,FILE$ERROR,FILE$FIRST,ERR$NOMEM,ERR$NOENT,FILE$DIR !引入库函数Implicit None!根据上面的语法介绍来定义变量Character*(*),Intent(In)::cFileName !筛选值character*(*),intent(In)::output !输出路径Integer,Intent(InOut)::iFile !记录已经找到几个文件TYPE (FILE$INFO) info !找到的文件的信息INTEGER(4)::Wildhandle,length !文件控制信息,文件大小,Wildhandle = FILE$FIRSTiFile = 0 DOWHILE (.TRUE.) !循环找文件 length = GetFileInfoQQ(cFileName,info,Wildhandle) !调用函数找文件!如果遇到错误或者不能再找到不同的文件,则进入选择,准备退出 IF ((Wildhandle .EQ.FILE$LAST) .OR.(Wildhandle .EQ. FILE$ERROR)) THEN SELECT CASE (GetLastErrorQQ()) CASE (ERR$NOMEM) !//内存不足 iFile = - 1 Return CASE (ERR$NOENT) !//碰到通配符序列尾,正常退出 Return CASE DEFAULT iFile =0 Return END SELECT END IF iFile= iFile +1 Call WriteFileName( Trim() ,outPut, iFile) !调用子函数输出文件名 ENDDO End Subroutine GetFileList注意,在调用子函数输出文件名时,要做一些处理,主要是判断文件是否存在(不存在则新建,如果是第一次找到,而且文件存在,则覆盖,否则追加),以及找到的是否为我们自己建立的这个dir.txt文件(如果是,则忽略,找到的文件数量-1)这个方法也不错,如果不需要子目录的信息,其优越性不亚于上一种方法,因为该子函数能够直接返回找到的文件数量。

相关文档
最新文档