java 中的文件类型 (Windows,unix)
File type in java (Windows,unix)
我实现了一个从命令行获取输入文件的代码。然后,对这个输入进行排序。然后将输出写入当前目录。我的代码有效,但我想知道那种类型的文件。
如图所示,我的 input.txt 类型是 dos\Windows。
我生成的 output.txt 类型是 UNIX。它们的大小也不同。为什么它们以不同的格式存储?我使用了,bufferedReader,fileWriter来实现这段代码。
code.java:
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.Arrays;
import java.io.FileWriter;
public class code{
public static void main(String[] args) {
try (BufferedReader br = new BufferedReader(new FileReader(args[0])))
{
int lines = 0;
while (br.readLine() != null) lines++; // to get text's number of lines
String sCurrentLine;
BufferedReader br2 = new BufferedReader(new FileReader(args[0])); //to read and sort the text
String[] array; //create a new array
array = new String[lines];
int i=0;
while ((sCurrentLine = br2.readLine()) != null) {//fill array with text content
array[i] = sCurrentLine;
i++;
}
Arrays.sort(array); //sort array
FileWriter fw = new FileWriter("output.txt");
for (i = 0; i < array.length; i++) { //write content of the array to file
fw.write(array[i] + "\n");
}
fw.close();
System.out.println("Process is finished.");
} catch (IOException e) {
e.printStackTrace();
}
}
}
input.txt:
x a t f a s f g h j n v x z s d f g b s c d e d d
output.txt :
a a b c d d d d e f f f g g h j n s s s t v x x z
SS-s
如何生成 windows 格式的输出文件(另外,它们的大小应该相同)?
Windows 上的行尾与其他平台上的不同。你总是写 "\n"
这是 Unix 行结尾。
虽然您可以简单地将它硬编码到 Windows 行结尾 ("\r\n"
),但如果您希望您的代码在任何地方都有效,您应该使用平台行分隔符。一种方法是从系统属性中获取它:
fw.write(array[i] + System.getProperty("line.separator"));
一种更易读的方法是用 Formatter:
替换你的 FileWriter
Formatter fw = new Formatter("output.txt");
for (i = 0; i < array.length; i++) { //write content of the array to file
fw.format("%s%n", array[i]);
}
fw.close();
您遇到的现象是 UN*X 系统和 Microsoft Windows 系统之间行尾字符的差异。这些系统更喜欢使用不同的字符序列来表示行结束。
- UN*X 系统使用 LF(换行)字符(
\n
,ASCII 中的 0x0A)
- Windows 系统使用一个 CR(回车 return)和一个 LF(换行)字符(
\r\n
,ASCII 中的 0x0D 和 0x0A)
您声明要使用 Windows 变体。在这种情况下,您不应将 "\n"
附加到新文件中的每一行。天真的方法是使用 "\r\n"
,但有更好的方法:
Java 使您能够获取当前平台的首选行尾字符序列。您可以通过调用 System.getProperty("line.separator")
(< Java 7) 或 System.lineSeparator()
(≥ Java 7).
来获取平台的行尾字符序列
因此,总而言之,您应该更改以下行:
fw.write(array[i] + "\n");
至
fw.write(array[i] + System.lineSeparator());
我实现了一个从命令行获取输入文件的代码。然后,对这个输入进行排序。然后将输出写入当前目录。我的代码有效,但我想知道那种类型的文件。 如图所示,我的 input.txt 类型是 dos\Windows。 我生成的 output.txt 类型是 UNIX。它们的大小也不同。为什么它们以不同的格式存储?我使用了,bufferedReader,fileWriter来实现这段代码。
code.java:
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.Arrays;
import java.io.FileWriter;
public class code{
public static void main(String[] args) {
try (BufferedReader br = new BufferedReader(new FileReader(args[0])))
{
int lines = 0;
while (br.readLine() != null) lines++; // to get text's number of lines
String sCurrentLine;
BufferedReader br2 = new BufferedReader(new FileReader(args[0])); //to read and sort the text
String[] array; //create a new array
array = new String[lines];
int i=0;
while ((sCurrentLine = br2.readLine()) != null) {//fill array with text content
array[i] = sCurrentLine;
i++;
}
Arrays.sort(array); //sort array
FileWriter fw = new FileWriter("output.txt");
for (i = 0; i < array.length; i++) { //write content of the array to file
fw.write(array[i] + "\n");
}
fw.close();
System.out.println("Process is finished.");
} catch (IOException e) {
e.printStackTrace();
}
}
}
input.txt:
x a t f a s f g h j n v x z s d f g b s c d e d d
output.txt :
a a b c d d d d e f f f g g h j n s s s t v x x z
SS-s
如何生成 windows 格式的输出文件(另外,它们的大小应该相同)?
Windows 上的行尾与其他平台上的不同。你总是写 "\n"
这是 Unix 行结尾。
虽然您可以简单地将它硬编码到 Windows 行结尾 ("\r\n"
),但如果您希望您的代码在任何地方都有效,您应该使用平台行分隔符。一种方法是从系统属性中获取它:
fw.write(array[i] + System.getProperty("line.separator"));
一种更易读的方法是用 Formatter:
替换你的 FileWriterFormatter fw = new Formatter("output.txt");
for (i = 0; i < array.length; i++) { //write content of the array to file
fw.format("%s%n", array[i]);
}
fw.close();
您遇到的现象是 UN*X 系统和 Microsoft Windows 系统之间行尾字符的差异。这些系统更喜欢使用不同的字符序列来表示行结束。
- UN*X 系统使用 LF(换行)字符(
\n
,ASCII 中的 0x0A) - Windows 系统使用一个 CR(回车 return)和一个 LF(换行)字符(
\r\n
,ASCII 中的 0x0D 和 0x0A)
您声明要使用 Windows 变体。在这种情况下,您不应将 "\n"
附加到新文件中的每一行。天真的方法是使用 "\r\n"
,但有更好的方法:
Java 使您能够获取当前平台的首选行尾字符序列。您可以通过调用 System.getProperty("line.separator")
(< Java 7) 或 System.lineSeparator()
(≥ Java 7).
因此,总而言之,您应该更改以下行:
fw.write(array[i] + "\n");
至
fw.write(array[i] + System.lineSeparator());