큰 텍스트 파일을 사용하여 약 5-6 GB 행별로 데릭쉐퍼드와 읽을 수 있는 것으로 나타났습니다.
어떻게 이렇게 빨리?
일반적인 패턴을 사용할 수 있다.
try (BufferedReader br = new BufferedReader(new FileReader(file))) {
String line;
while ((line = br.readLine()) != null) {
// process the line.
}
}
문자 인코딩 없는 solaris. 경우 데이터를 더욱 빠르게 읽을 수 있습니다. # 39 할 수 있지만, 예를 들어 ascii 7 won& 큰 차이가 없다. 데이터 처리 너희는너희가 훨씬 더 걸릴 가능성이 높다.
편집: '선' 덜 일반적인 패턴을 사용하는 것은 피할 수 있는 범위.
try(BufferedReader br = new BufferedReader(new FileReader(file))) {
for(String line; (line = br.readLine()) != null; ) {
// process the line.
}
// line is not visible here.
}
업데이트: 자바 가상 머신 (jvm) 에 8 할 수 있습니다.
try (Stream<String> stream = Files.lines(Paths.get(fileName))) {
stream.forEach(System.out::println);
}
참고: 함께 시도하시겠습니까 리소스에는 에서 스트리밍합니다 배치하십시오 할 수 있도록 방법을 블록 # it 에 대한 기본 파일 핸들, 그렇지 않으면 닫으십시오 호출됨 훨씬 나중에 단힌 보살피되 gc 는 절대 없습니다.
이걸봐 블로그:
>. 또는 버퍼 크기를 지정할 수 있습니다. >. 기본값입니다 크기 사용할 수 있습니다. 이 >. 충분히 큰 기본값: 대부분의 >. 작업을 할 수 있습니다.
// Open the file
FileInputStream fstream = new FileInputStream("textfile.txt");
BufferedReader br = new BufferedReader(new InputStreamReader(fstream));
String strLine;
//Read File Line By Line
while ((strLine = br.readLine()) != null) {
// Print the content on the console
System.out.println (strLine);
}
//Close the input stream
fstream.close();
[태그 jave 8] 는 한 번 아웃 (3월 2014년), 스트리밍합니다 you& # 39 사용할 수 있게 될 겁니다.
try (Stream<String> lines = Files.lines(Paths.get(filename), Charset.defaultCharset())) {
lines.forEachOrdered(line -> process(line));
}
모든 선은 인쇄면이 파일:
try (Stream<String> lines = Files.lines(file, Charset.defaultCharset())) {
lines.forEachOrdered(System.out::println);
}
다음은 샘플 완벽하게 오류 처리 및 지원을 위한 사양명세를 문자세트 사전 jave 7. Java 와 함께 사용할 수 있도록 하는 7 자원을 사용하여 시도하시겠습니까 코드 구문, 합성법.
그냥 기본값입니다 문자세트 필레이더 린퍼타슬림 건너뛰십시오 경우 사용할 수 있습니다.
InputStream ins = null; // raw byte-stream
Reader r = null; // cooked reader
BufferedReader br = null; // buffered for readLine()
try {
String s;
ins = new FileInputStream("textfile.txt");
r = new InputStreamReader(ins, "UTF-8"); // leave charset out for default
br = new BufferedReader(r);
while ((s = br.readLine()) != null) {
System.out.println(s);
}
}
catch (Exception e)
{
System.err.println(e.getMessage()); // handle exception
}
finally {
if (br != null) { try { br.close(); } catch(Throwable t) { /* ensure close happens */ } }
if (r != null) { try { r.close(); } catch(Throwable t) { /* ensure close happens */ } }
if (ins != null) { try { ins.close(); } catch(Throwable t) { /* ensure close happens */ } }
}
다음은 Groovy 버전, 완벽하게 오류 처리:
File f = new File("textfile.txt");
f.withReader("UTF-8") { br ->
br.eachLine { line ->
println line;
}
}
자바 가상 머신 (jvm) 에 8 할 수 있습니다.
try (Stream<String> lines = Files.lines (file, StandardCharsets.UTF_8))
{
for (String line : (Iterable<String>) lines::iterator)
{
;
}
}
일부 유라유라테이코쿠: '필요' (제품과는 달리 스트림까지) 청계천 반환되었습니다 피레스콜린스 의해 폐쇄되었다. 이러한 이유로 인해 [여기서 언급한] (https://stackoverflow.com/a/20177092/1151521) 나 사용하지 않는 '포리치 ()'. 그 이상한 코드 ' (String> Iterable<;) 스트림 '캐스트 흐름선 반복자가 충족되었으며 이트레이블.
당신이 무엇을 할 수 는 전체 텍스트 검색 스캐너를 거쳐 사용하여 텍스트 행별로. 물론 다음 가져와야 합니다.
import java.io.File;
import java.io.FileNotFoundException;
import java.util.Scanner;
public static void readText throws FileNotFoundException {
Scanner scan = new Scanner(new File("samplefilename.txt"));
while(scan.hasNextLine()){
String line = scan.nextLine();
//Here you can manipulate the string the way you want
}
}
기본적으로 모든 텍스트 검색 스캐너를. 그 동안 루프 전체 텍스트 트래버스할 데 사용됩니다.
콜하스네스틀린 반환하는 함수 () '이' 는 부울입니다 되면 더 많다는 줄을 사용한다. 이 '이네스틀린 ()' 기능을 사용하면 문자열으로 선으로 전체를 사용할 수 있는 방법을 적용할 수 있습니다. 시스템지우트리프린틀린 (선) '' 시도하시겠습니까 인쇄하려면 사용한다.
때는기대어 참고: .txt 파일 텍스트를 입력할 수 있다.
try {
BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(filePath), "Cp1252"));
String line;
while ((line = br.readLine()) != null) {
// process the line.
}
br.close();
} catch (IOException e) {
e.printStackTrace();
}
이 파일을 ANSI 인코딩으로 할 수도 있지만, Windows 에서 가져온 경우 (Cp1252) 이므로 인코딩입니다 지정해야 합니다.
자바 가상 머신 (jvm) 에 7:
String folderPath = "C:/folderOfMyFile";
Path path = Paths.get(folderPath, "myFileName.csv"); //or any text file eg.: txt, bat, etc
Charset charset = Charset.forName("UTF-8");
try (BufferedReader reader = Files.newBufferedReader(path , charset)) {
while ((line = reader.readLine()) != null ) {
//separate all csv fields into string array
String[] lineVariables = line.split(",");
}
} catch (IOException e) {
System.err.println(e);
}
내가 문서화했습니다 및 테스트되었습니다 10 개의 파일을 읽을 수 있는 자바 가상 머신 (jvm) 에 다음 읽을 수 있도록 그들을 통해 서로를 상대로 실행했음 테스트 파일의 1kb 의 1gb. 다음은 가장 빠른 방법은 판독값 3 개의 파일 판독값 1GB 테스트 절실해졌습니다.
단, t # 39 를 실행할 때 나는 아무것도 출력입니다 콘솔입니다 didn& 성능 테스트 이후에 정말로 늦출 테스트. 그냥 그들이성년에 테스트하려면 기초형상 판독값 속도.
자바 가상 머신 (jvm) 에 테스트되었습니다 7, 8, 9. 이는 전체 가장 빠른 방법. 판독값 1GB 파일을 바로 아래에 1 초 일관했다.
import java.io..File;
import java.io.IOException;
import java.nio.file.Files;
public class ReadFile_Files_ReadAllBytes {
public static void main(String [] pArgs) throws IOException {
String fileName = "c:\\temp\\sample-1GB.txt";
File file = new File(fileName);
byte [] fileBytes = Files.readAllBytes(file.toPath());
char singleChar;
for(byte b : fileBytes) {
singleChar = (char) b;
System.out.print(singleChar);
}
}
}
하지만 이 성공적으로 테스트되었습니다 자바 가상 머신 (jvm) 에 8 과 9 won& # 39, 자바 가상 머신 (jvm) 에 대한 지원 부족 때문에 람다 표현식에서는 7 빗나갔다. 그로부터 약 3.5 초 넣어 두 번째 파일을 읽을 수 있는 최대한 판독값 배치하십시오 1GB 대용량 파일.
import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.util.stream.Stream;
public class ReadFile_Files_Lines {
public static void main(String[] pArgs) throws IOException {
String fileName = "c:\\temp\\sample-1GB.txt";
File file = new File(fileName);
try (Stream linesStream = Files.lines(file.toPath())) {
linesStream.forEach(line -> {
System.out.println(line);
});
}
}
}
테스트됨 to work in jave 7, 8, 9. 이 약 4.5 초 1GB 테스트 파일을 읽을 수 있었다.
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
public class ReadFile_BufferedReader_ReadLine {
public static void main(String [] args) throws IOException {
String fileName = "c:\\temp\\sample-1GB.txt";
FileReader fileReader = new FileReader(fileName);
try (BufferedReader bufferedReader = new BufferedReader(fileReader)) {
String line;
while((line = bufferedReader.readLine()) != null) {
System.out.println(line);
}
}
}
전체 10 순위 모든 파일 판독값 방법을 찾을 수 있습니다. [here] [2].
[2]: https://funnelgarden.com/java_read_file/ # Performance_Rankings
자바 가상 머신 (jvm) 에 8, 또한 사용하는 대체 ['피레스콜린스 ()'] (https://stackoverflow.com/a/17866514/2986905). # 39 는 좀 더 추상적인 isn& 경우, 입력 소스 파일 같은 린퍼타슬림 ',' 하지만 '판독기에서 호스트였든' 선 () '의' 선 '을 통해 부퍼드레이더 메서드로부터 stream 수 있습니다.
예를 들면 다음과 같습니다.
<! - 언어: java - >.
try (BufferedReader reader = new BufferedReader(...)) {
reader.lines().forEach(line -> processLine(line));
}
'각' () 는 call '프로세스선 부퍼드레이더 입력선의 읽은'.
package com.java.java8;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.stream.Stream;
/**
* The Class ReadLargeFile.
*
* @author Ankit Sood Apr 20, 2017
*/
public class ReadLargeFile {
/**
* The main method.
*
* @param args
* the arguments
*/
public static void main(String[] args) {
try {
Stream<String> stream = Files.lines(Paths.get("C:\\Users\\System\\Desktop\\demoData.txt"));
stream.forEach(System.out::println);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
이를 위해서는 분명한 길을
예를 들면 다음과 같습니다.
'다테피레스테스트' 의 경우 현재 디렉토리에
import java.io.*;
import java.util.Scanner;
import java.io.FileNotFoundException;
public class readByLine
{
public readByLine() throws FileNotFoundException
{
Scanner linReader = new Scanner(new File("dataFile.txt"));
while (linReader.hasNext())
{
String line = linReader.nextLine();
System.out.println(line);
}
linReader.close();
}
public static void main(String args[]) throws FileNotFoundException
{
new readByLine();
}
}
아래 것처럼 출력물에는 ! [입력하십시오. 이미지 여기에 설명을] [1]
BufferedReader br;
FileInputStream fin;
try {
fin = new FileInputStream(fileName);
br = new BufferedReader(new InputStreamReader(fin));
/*Path pathToFile = Paths.get(fileName);
br = Files.newBufferedReader(pathToFile,StandardCharsets.US_ASCII);*/
String line = br.readLine();
while (line != null) {
String[] attributes = line.split(",");
Movie movie = createMovie(attributes);
movies.add(movie);
line = br.readLine();
}
fin.close();
br.close();
} catch (FileNotFoundException e) {
System.out.println("Your Message");
} catch (IOException e) {
System.out.println("Your Message");
}
작동하잖아 for me. 희망을 너무 도움이 된다.
난 보통 때는 판독값 일상적인 간단합니다.
void readResource(InputStream source) throws IOException {
BufferedReader stream = null;
try {
stream = new BufferedReader(new InputStreamReader(source));
while (true) {
String line = stream.readLine();
if(line == null) {
break;
}
//process line
System.out.println(line)
}
} finally {
closeQuiet(stream);
}
}
static void closeQuiet(Closeable closeable) {
if (closeable != null) {
try {
closeable.close();
} catch (IOException ignore) {
}
}
}
특히 기존 코드를 사용하여 제공했음 성능 향상 org.apache.commons.io 패키지 jave 사용하는 6 이하. 더 적은 수의 java7 API 는 예외 취급료 및 더 유용한 방법
LineIterator lineIterator =null;
try{
lineIterator = FileUtils.lineIterator(new File("/home/username/m.log"), "windows-1256");//second parameter is optionanl
while (lineIterator.hasNext()){
String currentLine = lineIterator.next();
//some operation
}
}finally {
LineIterator.closeQuietly(lineIterator);
}
메이븐
<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.6</version>
</dependency>