Ada 编程/库/Ada.Text_IO
此语言功能从 Ada 95 开始可用。
Ada.Text_IO 是 预定义语言环境 自 Ada 95 以来的一部分。
Text_IO 包用于简单文本格式的 输入输出 (I/O)。
Ada 2005 有一个函数 Get_Line,它返回一个包含整行的全新创建的字符串
functionGet_LinereturnString;
对于旧版本的 Ada,您需要一些工作才能用一次调用获取完整的行。Get_Line 过程获取一行文本,其字符数与 Item 可容纳的字符数相同或直至换行指示符,以先到者为准。(换行指示符的表示方式是特定于实现的。)它具有以下规范
procedureGet_Line (Item:outString; Last:outNatural);
具体来说,考虑一个可以容纳多达 80 个字符的 Item。让我们读取两行,一行少于 80 个字符,例如 10 个,另一行至少 80 个,可能更多。调用
Get_Line (Item, Last);
将读取第一行直至换行指示符并消耗它们;Item 的前 10 个字符将填充读取的文本,其余为垃圾;Last 将保存最后填充的索引。
下一个调用将读取 Item 可容纳的最大字符数,即 80 个字符;行的剩余部分(如果有)和换行指示符将保持未消耗状态。因此 Last 将为 Item'First - 1 + 80。为了消耗行的其余部分,您必须再次调用 Get_Line。结果将类似于以上两种情况之一,具体取决于剩余行长度。如果没有读取字符(即,当换行指示符是唯一未读内容时),Last 将保存值 Item'First - 1。
以下示例显示了如何读取完整行
withAda.Text_IO;withAda.Strings.Unbounded;functionGet_LinereturnStringispackageUstrrenamesAda.Strings.Unbounded;packageT_IOrenamesAda.Text_IO; Everything: Ustr.Unbounded_String := Ustr.Null_Unbounded_String; Item : String (1 .. 80); Last : Natural;beginGet_Whole_Line:loopT_IO.Get_Line (Item, Last); -- * Ustr.Append (Source => Everything, New_Item => Item (1 .. Last)); -- *exitGet_Whole_LinewhenLast < Item'Last; -- **endloopGet_Whole_Line;returnUstr.To_String (Everything);endGet_Line;
作为练习,将 (*) 处的调用更改为
T_IO.Get_Line (Item (11 .. 20), Last); Ustr.Append (Source => Everything, New_Item => Item (11 .. Last));
并查看 Item 和 Last 将保存哪些值。您将需要哪些标准才能在 (**) 处退出循环?
(当然,这样编码不是一个非常明智的想法,但作为学习指导,它是可以的。)
原则上与控制台读取相同,但您还需要检查文件结尾
exitGet_Whole_LinewhenLast < Item'LastorT_IO.End_Of_File (File);
对于控制台输入,End_of_File 始终为 False(除非您设法输入特定于实现的 end_of_file 指示符)。一个格式良好的文本文件(即使用 Ada.Text_IO 创建的文件)将在 end_of_file 指示符之前始终包含一个 end_of_line(以及一个 end_of_page)指示符(参见过程 Close)。
Ada.Text_IO 具有以下嵌套包,用于 标量类型 的输入/输出。唯一的参数是所涉及的类型。
- Decimal_IO
- Enumeration_IO
- Fixed_IO
- Float_IO
- Integer_IO
- Modular_IO
-- Standard Ada library specification -- Copyright (c) 2003-2018 Maxim Reznik <reznikmm@gmail.com> -- Copyright (c) 2004-2016 AXE Consultants -- Copyright (c) 2004, 2005, 2006 Ada-Europe -- Copyright (c) 2000 The MITRE Corporation, Inc. -- Copyright (c) 1992, 1993, 1994, 1995 Intermetrics, Inc. -- SPDX-License-Identifier: BSD-3-Clause and LicenseRef-AdaReferenceManual -- -------------------------------------------------------------------------withAda.IO_Exceptions;packageAda.Text_IOistypeFile_Typeislimitedprivate;typeFile_Modeis(In_File, Out_File, Append_File);typeCountisrange0 .. implementation_defined;subtypePositive_CountisCountrange1 .. Count'Last; Unbounded :constantCount := 0; -- line and page lengthsubtypeFieldisIntegerrange0 .. implementation_defined;subtypeNumber_BaseisIntegerrange2 .. 16;typeType_Setis(Lower_Case, Upper_Case); -- File ManagementprocedureCreate (File :inoutFile_Type; Mode :inFile_Mode := Out_File; Name :inString := ""; Form :inString := "");procedureOpen (File :inoutFile_Type; Mode :inFile_Mode; Name :inString; Form :inString := "");procedureClose (File :inoutFile_Type);procedureDelete (File :inoutFile_Type);procedureReset (File :inoutFile_Type; Mode :inFile_Mode);procedureReset (File :inoutFile_Type);functionMode (File :inFile_Type)returnFile_Mode;functionName (File :inFile_Type)returnString;functionForm (File :inFile_Type)returnString;functionIs_Open(File :inFile_Type)returnBoolean; -- Control of default input and output filesprocedureSet_Input (File :inFile_Type);procedureSet_Output(File :inFile_Type);procedureSet_Error (File :inFile_Type);functionStandard_InputreturnFile_Type;functionStandard_OutputreturnFile_Type;functionStandard_ErrorreturnFile_Type;functionCurrent_InputreturnFile_Type;functionCurrent_OutputreturnFile_Type;functionCurrent_ErrorreturnFile_Type;typeFile_AccessisaccessconstantFile_Type;functionStandard_InputreturnFile_Access;functionStandard_OutputreturnFile_Access;functionStandard_ErrorreturnFile_Access;functionCurrent_InputreturnFile_Access;functionCurrent_OutputreturnFile_Access;functionCurrent_ErrorreturnFile_Access; -- Buffer controlprocedureFlush (File :inoutFile_Type);procedureFlush; -- Specification of line and page lengthsprocedureSet_Line_Length (File :inFile_Type; To :inCount);procedureSet_Line_Length (To :inCount);procedureSet_Page_Length (File :inFile_Type; To :inCount);procedureSet_Page_Length (To :inCount);functionLine_Length (File :inFile_Type)returnCount;functionLine_LengthreturnCount;functionPage_Length (File :inFile_Type)returnCount;functionPage_LengthreturnCount; -- Column, Line, and Page ControlprocedureNew_Line (File :inFile_Type; Spacing :inPositive_Count := 1);procedureNew_Line (Spacing :inPositive_Count := 1);procedureSkip_Line (File :inFile_Type; Spacing :inPositive_Count := 1);procedureSkip_Line (Spacing :inPositive_Count := 1);functionEnd_Of_Line (File :inFile_Type)returnBoolean;functionEnd_Of_LinereturnBoolean;procedureNew_Page (File :inFile_Type);procedureNew_Page;procedureSkip_Page (File :inFile_Type);procedureSkip_Page;functionEnd_Of_Page (File :inFile_Type)returnBoolean;functionEnd_Of_PagereturnBoolean;functionEnd_Of_File (File :inFile_Type)returnBoolean;functionEnd_Of_FilereturnBoolean;procedureSet_Col (File :inFile_Type; To :inPositive_Count);procedureSet_Col (To :inPositive_Count);procedureSet_Line (File :inFile_Type; To :inPositive_Count);procedureSet_Line (To :inPositive_Count);functionCol (File :inFile_Type)returnPositive_Count;functionColreturnPositive_Count;functionLine (File :inFile_Type)returnPositive_Count;functionLinereturnPositive_Count;functionPage (File :inFile_Type)returnPositive_Count;functionPagereturnPositive_Count; -- Character Input-OutputprocedureGet (File :inFile_Type; Item :outCharacter);procedureGet (Item :outCharacter);procedurePut (File :inFile_Type; Item :inCharacter);procedurePut (Item :inCharacter);procedureLook_Ahead (File :inFile_Type; Item :outCharacter; End_Of_Line :outBoolean);procedureLook_Ahead (Item :outCharacter; End_Of_Line :outBoolean);procedureGet_Immediate (File :inFile_Type; Item :outCharacter);procedureGet_Immediate (Item :outCharacter);procedureGet_Immediate (File :inFile_Type; Item :outCharacter; Available :outBoolean);procedureGet_Immediate (Item :outCharacter; Available :outBoolean); -- String Input-OutputprocedureGet (File :inFile_Type; Item :outString);procedureGet (Item :outString);procedurePut (File :inFile_Type; Item :inString);procedurePut (Item :inString);procedureGet_Line (File :inFile_Type; Item :outString; Last :outNatural);procedureGet_Line (Item :outString; Last :outNatural);functionGet_Line(File :inFile_Type)returnString;functionGet_LinereturnString;procedurePut_Line (File :inFile_Type; Item :inString);procedurePut_Line (Item :inString); -- Generic packages for Input-Output of Integer TypesgenerictypeNumisrange<>;packageInteger_IOisDefault_Width : Field := Num'Width; Default_Base : Number_Base := 10;procedureGet (File :inFile_Type; Item :outNum; Width :inField := 0);procedureGet (Item :outNum; Width :inField := 0);procedurePut (File :inFile_Type; Item :inNum; Width :inField := Default_Width; Base :inNumber_Base := Default_Base);procedurePut (Item :inNum; Width :inField := Default_Width; Base :inNumber_Base := Default_Base);procedureGet (From :inString; Item :outNum; Last :outPositive);procedurePut (To :outString; Item :inNum; Base :inNumber_Base := Default_Base);endInteger_IO;generictypeNumismod<>;packageModular_IOisDefault_Width : Field := Num'Width; Default_Base : Number_Base := 10;procedureGet (File :inFile_Type; Item :outNum; Width :inField := 0);procedureGet (Item :outNum; Width :inField := 0);procedurePut (File :inFile_Type; Item :inNum; Width :inField := Default_Width; Base :inNumber_Base := Default_Base);procedurePut (Item :inNum; Width :inField := Default_Width; Base :inNumber_Base := Default_Base);procedureGet (From :inString; Item :outNum; Last :outPositive);procedurePut (To :outString; Item :inNum; Base :inNumber_Base := Default_Base);endModular_IO; -- Generic packages for Input-Output of Real TypesgenerictypeNumisdigits<>;packageFloat_IOisDefault_Fore : Field := 2; Default_Aft : Field := Num'Digits-1; Default_Exp : Field := 3;procedureGet (File :inFile_Type; Item :outNum; Width :inField := 0);procedureGet (Item :outNum; Width :inField := 0);procedurePut (File :inFile_Type; Item :inNum; Fore :inField := Default_Fore; Aft :inField := Default_Aft; Exp :inField := Default_Exp);procedurePut (Item :inNum; Fore :inField := Default_Fore; Aft :inField := Default_Aft; Exp :inField := Default_Exp);procedureGet (From :inString; Item :outNum; Last :outPositive);procedurePut (To :outString; Item :inNum; Aft :inField := Default_Aft; Exp :inField := Default_Exp);endFloat_IO;generictypeNumisdelta<>;packageFixed_IOisDefault_Fore : Field := Num'Fore; Default_Aft : Field := Num'Aft; Default_Exp : Field := 0;procedureGet (File :inFile_Type; Item :outNum; Width :inField := 0);procedureGet (Item :outNum; Width :inField := 0);procedurePut (File :inFile_Type; Item :inNum; Fore :inField := Default_Fore; Aft :inField := Default_Aft; Exp :inField := Default_Exp);procedurePut (Item :inNum; Fore :inField := Default_Fore; Aft :inField := Default_Aft; Exp :inField := Default_Exp);procedureGet (From :inString; Item :outNum; Last :outPositive);procedurePut (To :outString; Item :inNum; Aft :inField := Default_Aft; Exp :inField := Default_Exp);endFixed_IO;generictypeNumisdelta<>digits<>;packageDecimal_IOisDefault_Fore : Field := Num'Fore; Default_Aft : Field := Num'Aft; Default_Exp : Field := 0;procedureGet (File :inFile_Type; Item :outNum; Width :inField := 0);procedureGet (Item :outNum; Width :inField := 0);procedurePut (File :inFile_Type; Item :inNum; Fore :inField := Default_Fore; Aft :inField := Default_Aft; Exp :inField := Default_Exp);procedurePut (Item :inNum; Fore :inField := Default_Fore; Aft :inField := Default_Aft; Exp :inField := Default_Exp);procedureGet (From :inString; Item :outNum; Last :outPositive);procedurePut (To :outString; Item :inNum; Aft :inField := Default_Aft; Exp :inField := Default_Exp);endDecimal_IO; -- Generic package for Input-Output of Enumeration TypesgenerictypeEnumis(<>);packageEnumeration_IOisDefault_Width : Field := 0; Default_Setting : Type_Set := Upper_Case;procedureGet (File :inFile_Type; Item :outEnum);procedureGet (Item :outEnum);procedurePut (File :inFile_Type; Item :inEnum; Width :inField := Default_Width; Set :inType_Set := Default_Setting);procedurePut (Item :inEnum; Width :inField := Default_Width; Set :inType_Set := Default_Setting);procedureGet (From :inString; Item :outEnum; Last :outPositive);procedurePut (To :outString; Item :inEnum; Set :inType_Set := Default_Setting);endEnumeration_IO; -- Exceptions Status_Error :exceptionrenamesIO_Exceptions.Status_Error; Mode_Error :exceptionrenamesIO_Exceptions.Mode_Error; Name_Error :exceptionrenamesIO_Exceptions.Name_Error; Use_Error :exceptionrenamesIO_Exceptions.Use_Error; Device_Error :exceptionrenamesIO_Exceptions.Device_Error; End_Error :exceptionrenamesIO_Exceptions.End_Error; Data_Error :exceptionrenamesIO_Exceptions.Data_Error; Layout_Error :exceptionrenamesIO_Exceptions.Layout_Error;privatetypeFile_Typeislimitednullrecord;endAda.Text_IO;
外部示例
[编辑源代码]- 在以下位置搜索
Ada.Text_IO的 **示例**:Rosetta Code、GitHub (gists)、任何 Alire 包 或 本。 - 在以下位置搜索与
Ada.Text_IO相关的 **帖子**:Stack Overflow、comp.lang.ada 或 任何与 Ada 相关的页面。
FSF GNAT
- 规范:a-textio.ads
- 主体:a-textio.adb
drake
