Visible to Intel only — GUID: GUID-EC61DE8C-A087-4984-9CA5-5199137730AB
Visible to Intel only — GUID: GUID-EC61DE8C-A087-4984-9CA5-5199137730AB
Format Specifications
A format specification can appear in a FORMAT statement or a character expression. In a FORMAT statement, it is preceded by the keyword FORMAT. A format specification takes one of the following forms:
( [format-items])
( [format-items, ] unlimited-format-item)
format-items |
Is format-items [[,] format-item]... where format-item is one of the following:
|
- r
- (Optional) Is an integer literal constant. This is called a repeat specification. The range of r is 1 through 2147483647 (2**31-1). If r is omitted, it is assumed to be 1.
- data-edit-desc
-
Is one of the data edit descriptors: I, B, O, Z, F, E, EN, ES, EX, D, DT, G, L, or A.
A repeat specification can precede any data edit descriptor.
- control-edit-desc
-
Is one of the control edit descriptors: T, TL, TR, X, S, SP, SS, BN, BZ, P, :, /, $, \, and Q.
A repeat specification can precede the slash (/) edit descriptor.
- char-string-edit-desc
- Is one of the string edit descriptors: H, 'c', and "c", where c is a character constant.
- unlimited-format-item
- Is * (format-items). The * indicates an unlimited repeat count.
If more than one edit descriptor is specified, they must be separated by commas or slashes (/).
A comma can be omitted in the following cases:
Between a P edit descriptor and an immediately following F, E, EN, ES, EX, D, or G edit descriptor
Before a slash (/) edit descriptor when the optional repeat specification is not present
After a slash (/) edit descriptor
Before or after a colon (:) edit descriptor
Description
A FORMAT statement must be labeled.
Named constants are not permitted in format specifications.
If the associated I/O statement contains an I/O list, the format specification must contain at least one data edit descriptor or the control edit descriptor Q.
Blank characters can precede the initial left parenthesis, and additional blanks can appear anywhere within the format specification. These blanks have no meaning unless they are within a character string edit descriptor.
When a formatted input statement is executed, the setting of the BLANK specifier (for the relevant logical unit) determines the interpretation of blanks within the specification. If the BN or BZ edit descriptors are specified for a formatted input statement, they supersede the default interpretation of blanks. (For more information on BLANK defaults, see BLANK Specifier in OPEN statements.)
For formatted input, you can use the comma as an external field separator. The comma terminates the input of fields (for non-character data types) that are shorter than the number of characters expected. It can also designate null (zero-length) fields.
The following table summarizes the edit descriptors that can be used in format specifications.
Code |
Form |
Effect |
---|---|---|
A[w] |
Transfers character or Hollerith values. |
|
Bw[.m] |
Transfers binary values. |
|
BN |
Ignores embedded and trailing blanks in a numeric input field. |
|
BZ |
Treats embedded and trailing blanks in a numeric input field as zeros. |
|
Dw.d |
Transfers real values with D exponents. |
|
DT [string] [(v-list)] |
Passes a character string and an integer array to a defined I/O procedure. |
|
Ew.d[Ee] |
Transfers real values with E exponents. |
|
ENw.d[Ee] |
Transfers real values with engineering notation. |
|
ESw.d[Ee] |
Transfers real values with scientific notation. |
|
EXw.d[Ee] |
Transfers real values with hexadecimal-significands. |
|
Fw.d |
Transfers real values with no exponent. |
|
Gw.d[Ee] |
Transfers values of all intrinsic types. |
|
nHch[ch...] |
Transfers characters following the H edit descriptor to an output record. |
|
Iw[.m] |
Transfers decimal integer values. |
|
Lw |
Transfers logical values: on input, transfers characters; on output, transfers T or F. |
|
Ow[.m] |
Transfers octal values. |
|
kP |
Interprets certain real numbers with a specified scale factor. |
|
Q |
Returns the number of characters remaining in an input record. |
|
S |
Reinvokes optional plus sign (+) in numeric output fields; counters the action of SP and SS. |
|
SP |
Writes optional plus sign (+) into numeric output fields. |
|
SS |
Suppresses optional plus sign (+) in numeric output fields. |
|
Tn |
Tabs to specified position. |
|
TLn |
Tabs left the specified number of positions. |
|
TRn |
Tabs right the specified number of positions. |
|
nX |
Skips the specified number of positions. |
|
Zw[.m] |
Transfers hexadecimal values. |
|
$ |
Suppresses trailing carriage return during interactive I/O. |
|
: |
Terminates format control if there are no more items in the I/O list. |
|
[r]/ |
Terminates the current record and moves to the next record. |
|
\ |
Continues the same record; same as $. |
|
'c' |
Transfers the character literal constant (between the delimiters) to an output record. |
|
1 These delimiters can also be quotation marks ("). |
Character Format Specifications
In data transfer I/O statements, a format specifier ([FMT=]format) can be a character expression that is a character array, character array element, or character constant. This type of format is also called a runtime format because it can be constructed or altered during program execution.
The expression must evaluate to a character string whose leading part is a valid format specification (including the enclosing parentheses).
If the expression is a character array element, the format specification must be contained entirely within that element.
If the expression is a character array, the format specification can continue past the first element into subsequent consecutive elements.
If the expression is a character constant delimited by apostrophes, use two consecutive apostrophes ('' ) to represent an apostrophe character in the format specification; for example:
PRINT '("NUM can''t be a real number")'
Similarly, if the expression is a character constant delimited by quotation marks, use two consecutive quotation marks ("") to represent a quotation mark character in the format specification.
To avoid using consecutive apostrophes or quotation marks, you can put the character constant in an I/O list instead of a format specification, as follows:
PRINT "(A)", "NUM can't be a real number"
The following shows another character format specification:
WRITE (6, '(I12, I4, I12)') I, J, K
In the following example, the format specification changes with each iteration of the DO loop:
SUBROUTINE PRINT(TABLE)
REAL TABLE(10,5)
CHARACTER*5 FORCHR(0:5), RPAR*1, FBIG, FMED, FSML
DATA FORCHR(0),RPAR /'(',')'/
DATA FBIG,FMED,FSML /'F8.2,','F9.4,','F9.6,'/
DO I=1,10
DO J=1,5
IF (TABLE(I,J) .GE. 100.) THEN
FORCHR(J) = FBIG
ELSE IF (TABLE(I,J) .GT. 0.1) THEN
FORCHR(J) = FMED
ELSE
FORCHR(J) = FSML
END IF
END DO
FORCHR(5)(5:5) = RPAR
WRITE (6,FORCHR) (TABLE(I,J), J=1,5)
END DO
END
The DATA statement assigns a left parenthesis to character array element FORCHR(0), and (for later use) a right parenthesis and three F edit descriptors to character variables.
Next, the proper F edit descriptors are selected for inclusion in the format specification. The selection is based on the magnitude of the individual elements of array TABLE.
A right parenthesis is added to the format specification just before the WRITE statement uses it.
Format specifications stored in arrays are recompiled at runtime each time they are used. If a Hollerith or character runtime format is used in a READ statement to read data into the format itself, that data is not copied back into the original array, and the array is unavailable for subsequent use as a runtime format specification.
Examples
The following example shows a format specification:
WRITE (*, 9000) int1, real1(3), char1
9000 FORMAT (I5, 3F4.5, A16)
! I5, 3F5.2, A16 is the format list.
The following shows a format example using a character expression:
WRITE (*, '(I5, 3F5.2, A16)')iolist
! I5, 3F4.5, A16 is the format list.
In the following example, the format list is put into an 80-character variable called MYLIST:
CHARACTER(80) MYLIST
MYLIST = '(I5, 3F5.2, A16)'
WRITE (*, MYLIST) iolist
Consider the following two-dimensional array:
1 2 3 4 5 6
In this case, the elements are stored in memory in the order: 1, 4, 2, 5, 3, 6 as follows:
CHARACTER(6) array(3)
DATA array / '(I5', ',3F5.2', ',A16)' /
WRITE (*, array) iolist
In the following example, the WRITE statement uses the character array element array(2) as the format specifier for data transfer:
CHARACTER(80) array(5)
array(2) = '(I5, 3F5.2, A16)'
WRITE (*, array(2)) iolist