Como faço para salvar uma String em um arquivo de texto usando Java?


699

Em Java, tenho texto de um campo de texto em uma variável String chamada "text".

Como posso salvar o conteúdo da variável "texto" em um arquivo?

Respostas:


727

Se você estiver simplesmente produzindo texto, em vez de quaisquer dados binários, o seguinte funcionará:

PrintWriter out = new PrintWriter("filename.txt");

Em seguida, escreva sua String, como faria em qualquer fluxo de saída:

out.println(text);

Você precisará de tratamento de exceção, como sempre. Certifique-se de ligarout.close() quando terminar de escrever.

Se você estiver usando o Java 7 ou posterior, poderá usar a " instrução try-with-resources ", que fechará automaticamente PrintStreamquando você terminar (por exemplo, sair do bloco) da seguinte maneira:

try (PrintWriter out = new PrintWriter("filename.txt")) {
    out.println(text);
}

Você ainda precisará lançar explicitamente o java.io.FileNotFoundExceptioncomo antes.


4
@Justin, você também pode passar um caminho absoluto (por exemplo, "/tmp/filename.txt") para o construtor FileOutputStream, para salvar o arquivo em qualquer lugar que você quer
Jonik

7
Btw, isso poderia ser simplificado usando os construtores de conveniência que PrintStream tem desde 1,5. Isso seria suficiente: PrintStream out = new PrintStream ("filename.txt");
28611 Jonik

10
Precisa fechar esse arquivo em algum momento ...? codecodex.com/wiki/ASCII_file_save#Java
JStrahl

2
Você deseja usar try {} catch () {} finalmente {}, onde finalmente {} você fecha o arquivo se ele não for nulo.
Benas

23
No java8, você pode tentar (PrintStream ps = new PrintStream ("filename")) {ps.println (out); } isso vai cuidar de você
Anton Chikin

245

O Apache Commons IO contém ótimos métodos para fazer isso, em particular o FileUtils contém o seguinte método:

static void writeStringToFile(File file, String data) 

que permite escrever texto em um arquivo em uma chamada de método:

FileUtils.writeStringToFile(new File("test.txt"), "Hello File");

Você também pode querer especificar a codificação do arquivo.


10
Apenas uma pequena correção, o segundo fragmento deve ler: FileUtils.writeStringToFile (new File ("test.txt"), "Hello File");
Pm_labs

3
Para aqueles de nós que preferem a goiaba, isso também pode ser feito .
Jonik

10
A função agora está obsoleta, você deve adicionar o conjunto de caracteres padrão ->FileUtils.writeStringToFile(new File("test.txt"), "Hello File", forName("UTF-8"));
Paul Fournel

97

Dê uma olhada na API de arquivos Java

um exemplo rápido:

try (PrintStream out = new PrintStream(new FileOutputStream("filename.txt"))) {
    out.print(text);
}

@ XP1 Eu sei, isso é uma grande melhoria. Eu usei o Lombok para isso no Java 6: basta ir @Cleanup new FileOutputStream(...)e pronto.
Jorn

6
Não se esqueça de chamar out.flush (); então out.close ();
precisa saber é o seguinte

@AlexByrth, por que deveria?
Andrew Tobilko

1
Arquivos grandes são gravados em segundo plano (outro segmento) e levam um tempo para serem gravados. Chamar flush () garante que tudo tenha sido escrito na próxima linha, sincronizando a operação. Mas isso é opcional , mas é uma boa prática se você manipular arquivos grandes, como logs.
Alex Byrth

1
Observe que out.close () já libera o fluxo, o que significa que não é necessário chamar out.flush ().
Hjk321 31/12/19

90

No Java 7, você pode fazer isso:

String content = "Hello File!";
String path = "C:/a.txt";
Files.write( Paths.get(path), content.getBytes());

Há mais informações aqui: http://www.drdobbs.com/jvm/java-se-7-new-file-io/231600403


3
Caso alguém mais tarde se perguntasse, a codificação seria o padrão da plataforma.
Haakon Løtveit 29/11

5
content.getBytes(StandardCharsets.UTF_8)pode ser usado para definir explicitamente a codificação.
precisa saber é o seguinte

1
Observe que StandardOpenOption.CREATE não é o padrão StandardOpenOption.CREATE e StandardOpenOption.TRUNCATE_EXISTING é o padrão. Para usar o padrão, basta remover o terceiro parâmetro.
Tinus Tate

Por favor, veja o comentário de Tinus Tate! Qual é o processo para editar este exemplo? Gostaria de saber quantas milhares de pessoas adotaram esse exemplo apenas para descobrir que têm resultados inesperados quando substituem um arquivo com uma string mais curta. Como indica o Tinus, TRUNCATE_EXISTING é crucial, a menos que você entenda completamente e tenha um motivo real para não querer truncar o arquivo existente ao substituir por uma sequência mais curta.
jch 8/10/19

1
No Java 11, você pode simplesmente colocar uma String como um segundo parâmetro! Viva!
precisa

78

Acabei de fazer algo semelhante no meu projeto. O uso do FileWriter simplificará parte do seu trabalho. E aqui você pode encontrar um bom tutorial .

BufferedWriter writer = null;
try
{
    writer = new BufferedWriter( new FileWriter( yourfilename));
    writer.write( yourstring);

}
catch ( IOException e)
{
}
finally
{
    try
    {
        if ( writer != null)
        writer.close( );
    }
    catch ( IOException e)
    {
    }
}

4
Removendo todos os try / catch e simplificando-o, também posso fazer isso em uma linha apenas fazendo o seguinte: (new BufferedWriter (novo FileWriter (nome do arquivo))). Write (str);
Artem Barger

6
Então, mostre sua solução simples e agradável. Eu ficaria feliz em aprender como fazê-lo da melhor maneira.
Artem Barger

4
Ignore os trolls ... eles sempre criticam sem oferecer sua própria solução. Obrigado por me salvar de escrever meu próprio código / download biblioteca extra & introduzindo dependência ...
nikib3ro

1
Parece que .close()não joga (pelo menos no Java 7?), O último trycatch talvez seja redundante?
Kos

16
A deglutição de exceções como essa dificulta a vida de você quando ocorrem realmente. No mínimo você deve relançar eles:throw new RuntimeException(e);
Roger Keays

65

Use FileUtils.writeStringToFile()do Apache Commons IO . Não há necessidade de reinventar essa roda em particular.


20
Eu não poderia discordar mais. Essas bibliotecas existem para que não introduzamos erros sutis em uma solução tão simples.
27410 skaffman

3
Não, obviamente não. Só estou discordando que sua solução pode não ser a primeira coisa que eu daria a alguém que é um programador iniciante em Java. Você não está sugerindo que nunca tenha escrito algo assim, está?
duffymo

8
Sim, mas isso foi antes de encontrar o commons-io. Desde que descobri isso, nunca escrevi esse tipo de coisa manualmente, mesmo em um projeto de uma classe. Se eu soubesse disso desde o primeiro dia, teria usado desde o primeiro dia.
27410 skaffman

5
Exatamente, mas você é um desenvolvedor experiente. Sua biografia diz que você é um usuário do JBOSS / Spring, mas certamente você não teria gostado de nenhuma delas no seu primeiro esforço "Olá, Mundo". Não discordo do uso adequado de bibliotecas. Estou dizendo que as pessoas que tentam um idioma pela primeira vez devem tentar conhecê-lo no fundo, mesmo que isso signifique fazer coisas que descartarão mais tarde quando tiverem experiência e conhecerem melhor.
duffymo

2
Eu implementei isso sem bens comuns e recebi uma exceção menos que óbvia lançada. Eu então implementei isso usando bens comuns e ele me disse exatamente o que estava errado. Moral da história: por que viver na idade das trevas se você não precisa?
criar o seu alerta

22

Você pode modificar o código abaixo para gravar seu arquivo de qualquer classe ou função que esteja manipulando o texto. É de se perguntar por que o mundo precisa de um novo editor de texto ...

import java.io.*;

public class Main {

    public static void main(String[] args) {

        try {
            String str = "SomeMoreTextIsHere";
            File newTextFile = new File("C:/thetextfile.txt");

            FileWriter fw = new FileWriter(newTextFile);
            fw.write(str);
            fw.close();

        } catch (IOException iox) {
            //do stuff with exception
            iox.printStackTrace();
        }
    }
}

2
Isso não fecha o arquivo em caso de exceção.
Tom Hawtin - tackline 27/06/09

1
@JanusTroelsen: se rejeitado, cite a declaração try-with-resources .
Trashgod

22

No Java 11, a java.nio.file.Filesclasse foi estendida por dois novos métodos utilitários para gravar uma string em um arquivo. O primeiro método (consulte JavaDoc aqui ) usa o conjunto de caracteres UTF-8 como padrão:

Files.writeString(Path.of("my", "path"), "My String");

E o segundo método (consulte JavaDoc aqui ) permite especificar um conjunto de caracteres individual:

Files.writeString(Path.of("my", "path"), "My String", StandardCharset.ISO_8859_1);

Ambos os métodos têm um parâmetro Varargs opcional para definir opções de manipulação de arquivos (consulte JavaDoc aqui ). O exemplo a seguir criaria um arquivo inexistente ou anexaria a sequência a um existente:

Files.writeString(Path.of("my", "path"), "String to append", StandardOpenOption.CREATE, StandardOpenOption.APPEND);

13

Prefiro confiar nas bibliotecas sempre que possível para esse tipo de operação. Isso me deixa menos propenso a omitir acidentalmente um passo importante (como erro cometido pelos lobos acima). Algumas bibliotecas são sugeridas acima, mas a minha favorita para esse tipo de coisa é o Google Guava . O Goiaba possui uma classe chamada Arquivos, que funciona muito bem para esta tarefa:

// This is where the file goes.
File destination = new File("file.txt");
// This line isn't needed, but is really useful 
// if you're a beginner and don't know where your file is going to end up.
System.out.println(destination.getAbsolutePath());
try {
    Files.write(text, destination, Charset.forName("UTF-8"));
} catch (IOException e) {
    // Useful error handling here
}

2
Se você estiver usando o Goiaba, também há Charsets.UTF-8.
florian

2
@florian: É Charsets.UTF_8verdade
Tim Buthe

A pasta pai deve existir. Exemplo: destination.mkdirs ().
AlikElzin-Kilaka

2
Files.write (CharSequence from, File to, Charset charset) está obsoleto na goiaba 26.0.
Donald Duck

Alternativa moderna da Goiaba para o Files.write obsoleto:Files.asCharSink(file, charset).write(text)
Vadzim

12

Use o Apache Commons IO api. É simples

Use API como

 FileUtils.writeStringToFile(new File("FileNameToWrite.txt"), "stringToWrite");

Dependência do Maven

<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.4</version>
</dependency>

12

Caso você precise criar um arquivo de texto com base em uma única sequência:

import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;

public class StringWriteSample {
    public static void main(String[] args) {
        String text = "This is text to be saved in file";

        try {
            Files.write(Paths.get("my-file.txt"), text.getBytes());
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

Files.write (path, byte []) usará a codificação UTF-8. String.getBytes () usa a codificação da plataforma padrão. Portanto, esse é um problema em potencial. Use string.getBytes (StandardCharsets.UTF_8)!
rmuller

11

Use isto, é muito legível:

import java.nio.file.Files;
import java.nio.file.Paths;

Files.write(Paths.get(path), lines.getBytes(), StandardOpenOption.WRITE);

Também é uma cópia de uma resposta existente. : c
james.garriss 21/07

2
desculpe, mas eu não inventei java8, eu não sou o único que usa esta linha. mas não é um passado exemplar de outras respostas para a mesma pergunta
Ran Adler

10
import java.io.*;

private void stringToFile( String text, String fileName )
 {
 try
 {
    File file = new File( fileName );

    // if file doesnt exists, then create it 
    if ( ! file.exists( ) )
    {
        file.createNewFile( );
    }

    FileWriter fw = new FileWriter( file.getAbsoluteFile( ) );
    BufferedWriter bw = new BufferedWriter( fw );
    bw.write( text );
    bw.close( );
    //System.out.println("Done writing to " + fileName); //For testing 
 }
 catch( IOException e )
 {
 System.out.println("Error: " + e);
 e.printStackTrace( );
 }
} //End method stringToFile

Você pode inserir esse método em suas classes. Se você estiver usando esse método em uma classe com um método principal, altere essa classe para estática adicionando a palavra-chave estática. De qualquer forma, você precisará importar o java.io. * para fazê-lo funcionar, caso contrário, File, FileWriter e BufferedWriter não serão reconhecidos.


10

Você poderia fazer isso:

import java.io.*;
import java.util.*;

class WriteText
{
    public static void main(String[] args)
    {   
        try {
            String text = "Your sample content to save in a text file.";
            BufferedWriter out = new BufferedWriter(new FileWriter("sample.txt"));
            out.write(text);
            out.close();
        }
        catch (IOException e)
        {
            System.out.println("Exception ");       
        }

        return ;
    }
};

10

Usando Java 7:

public static void writeToFile(String text, String targetFilePath) throws IOException
{
    Path targetPath = Paths.get(targetFilePath);
    byte[] bytes = text.getBytes(StandardCharsets.UTF_8);
    Files.write(targetPath, bytes, StandardOpenOption.CREATE);
}

Uma palavra para o sábio - isso criará um novo arquivo se não estiver lá, mas substituirá os caracteres do arquivo existente, se estiver. Se os novos dados forem menores, isso significa que você provavelmente criará um arquivo corrompido. Me pergunte como eu sei!
Chris Rae

Ok, como você sabe?
ojblass

Basta usar Files.write(targetPath, bytes);para substituir o arquivo então. Funcionará como esperado.
BullyWiiPlaza 10/03

8

Usando org.apache.commons.io.FileUtils:

FileUtils.writeStringToFile(new File("log.txt"), "my string", Charset.defaultCharset());

6

Se você se preocupa apenas em enviar um bloco de texto para o arquivo, ele será sobrescrito a cada vez.

JFileChooser chooser = new JFileChooser();
int returnVal = chooser.showSaveDialog(this);
if (returnVal == JFileChooser.APPROVE_OPTION) {
    FileOutputStream stream = null;
    PrintStream out = null;
    try {
        File file = chooser.getSelectedFile();
        stream = new FileOutputStream(file); 
        String text = "Your String goes here";
        out = new PrintStream(stream);
        out.print(text);                  //This will overwrite existing contents

    } catch (Exception ex) {
        //do something
    } finally {
        try {
            if(stream!=null) stream.close();
            if(out!=null) out.close();
        } catch (Exception ex) {
            //do something
        }
    }
}

Este exemplo permite que o usuário selecione um arquivo usando um seletor de arquivos.


@Eric Leschinski: obrigado por fazer a minha resposta mais profissional (i também assumiu este foi exatamente o que o OP queria uma vez que este é o que realmente a maioria das pessoas quer, simplesmente despejar o texto e substituí-lo)
bhathiya-perera

2
Depois que a pergunta original é respondida e o OP está satisfeito e desaparecido, páginas como essa servem apenas como um artefato útil para as pessoas que chegam aqui a partir de uma pesquisa no Google. Cheguei nesta página para criar um mini aplicativo de texto em um arquivo. Portanto, é bom falar com todo o público e não com o OP depois que o OP foi adiante.
Eric Leschinski

3

É melhor fechar o gravador / fluxo de saída em um bloco final, caso algo aconteça

finally{
   if(writer != null){
     try{
        writer.flush();
        writer.close();
     }
     catch(IOException ioe){
         ioe.printStackTrace();
     }
   }
}

1
ainda melhor: usar try-with-resources
Janus Troelsen

Sim, @JanusTroelsen é certo, utilizar melhor o try-with-recursos declaração docs.oracle.com/javase/tutorial/essential/exceptions/...

2
private static void generateFile(String stringToWrite, String outputFile) {
try {       
    FileWriter writer = new FileWriter(outputFile);
    writer.append(stringToWrite);
    writer.flush();
    writer.close();
    log.debug("New File is generated ==>"+outputFile);
} catch (Exception exp) {
    log.error("Exception in generateFile ", exp);
}

}


1
Embora esse snippet de código possa ser a solução, incluir uma explicação realmente ajuda a melhorar a qualidade da sua postagem. Lembre-se de que você está respondendo à pergunta dos leitores no futuro e essas pessoas podem não saber os motivos da sua sugestão de código.
10269 Johan

close () nunca pode ser chamado. Melhore sua resposta adicionando o tratamento adequado de casos de erro.
Boris Brodski 27/04

0

Eu acho que a melhor maneira é usar Files.write(Path path, Iterable<? extends CharSequence> lines, OpenOption... options):

String text = "content";
Path path = Paths.get("path", "to", "file");
Files.write(path, Arrays.asList(text));

Veja javadoc :

Escreva linhas de texto em um arquivo. Cada linha é uma sequência de caracteres e é gravada no arquivo em sequência com cada linha terminada pelo separador de linhas da plataforma, conforme definido pela propriedade do sistema line.separator. Os caracteres são codificados em bytes usando o conjunto de caracteres especificado.

O parâmetro options especifica como o arquivo é criado ou aberto. Se nenhuma opção estiver presente, esse método funcionará como se as opções CREATE, TRUNCATE_EXISTING e WRITE estivessem presentes. Em outras palavras, ele abre o arquivo para gravação, criação do arquivo se ele não existir ou truncamento inicial de um arquivo regular existente para um tamanho de 0. O método garante que o arquivo seja fechado quando todas as linhas forem gravadas ( ou um erro de E / S ou outra exceção de tempo de execução). Se ocorrer um erro de E / S, poderá ocorrer após o arquivo ter sido criado ou truncado ou após a gravação de alguns bytes no arquivo.

Observe. Vejo que as pessoas já responderam com o Java embutido Files.write, mas o que é especial na minha resposta, que ninguém parece mencionar, é a versão sobrecarregada do método, que utiliza um Iterable de CharSequence (ou seja, String), em vez de uma byte[]matriz, portanto, text.getBytes()não é necessário. , que é um pouco mais limpo, eu acho.


0

Se você deseja manter os caracteres de retorno de carro da string em um arquivo, aqui está um exemplo de código:

    jLabel1 = new JLabel("Enter SQL Statements or SQL Commands:");
    orderButton = new JButton("Execute");
    textArea = new JTextArea();
    ...


    // String captured from JTextArea()
    orderButton.addActionListener(new ActionListener() {
        public void actionPerformed(ActionEvent ae) {
            // When Execute button is pressed
            String tempQuery = textArea.getText();
            tempQuery = tempQuery.replaceAll("\n", "\r\n");
            try (PrintStream out = new PrintStream(new FileOutputStream("C:/Temp/tempQuery.sql"))) {
                out.print(tempQuery);
            } catch (FileNotFoundException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            System.out.println(tempQuery);
        }

    });

-1

Meu caminho é baseado no fluxo devido à execução em todas as versões do Android e nas necessidades de recursos adequados, como URL / URI, qualquer sugestão é bem-vinda.

No que diz respeito a fluxos, os fluxos (InputStream e OutputStream) transferem dados binários, quando o desenvolvedor grava uma sequência em um fluxo, deve primeiro convertê-los em bytes ou, em outras palavras, codificá-los.

public boolean writeStringToFile(File file, String string, Charset charset) {
    if (file == null) return false;
    if (string == null) return false;
    return writeBytesToFile(file, string.getBytes((charset == null) ? DEFAULT_CHARSET:charset));
}

public boolean writeBytesToFile(File file, byte[] data) {
    if (file == null) return false;
    if (data == null) return false;
    FileOutputStream fos;
    BufferedOutputStream bos;
    try {
        fos = new FileOutputStream(file);
        bos = new BufferedOutputStream(fos);
        bos.write(data, 0, data.length);
        bos.flush();
        bos.close();
        fos.close();
    } catch (IOException e) {
        e.printStackTrace();
        Logger.e("!!! IOException");
        return false;
    }
    return true;
}

1
Adicione manipulação de caso de erro adequada, fechando todos os recursos abertos e propagando exceções
Boris Brodski

Você se importaria em compartilhar casos de manipulação de código conforme recomendado, obrigado.
牟家宏

-1

Você pode usar o ArrayList para colocar todo o conteúdo da TextArea por exemplo, e enviar como parâmetro chamando o save, como o escritor acabou de escrever as linhas da string, então usamos o "for" linha por linha para escrever nosso ArrayList no final estaremos conteúdo TextArea no arquivo txt. se algo não faz sentido, me desculpe é o google tradutor e eu que não falamos inglês.

Assista ao bloco de notas do Windows, ele nem sempre pula linhas e mostra tudo em uma linha, use o Wordpad ok.


private void SaveActionPerformed(java.awt.event.ActionEvent evt) {

    String NameFile = Name.getText();
    ArrayList< String > Text = new ArrayList< String >();

    Text.add(TextArea.getText());

    SaveFile(NameFile, Text);
}

public void SaveFile(String name, ArrayList< String> message) {

    path = "C:\\Users\\Paulo Brito\\Desktop\\" + name + ".txt";

    File file1 = new File(path);

    try {

        if (!file1.exists()) {

            file1.createNewFile();
        }


        File[] files = file1.listFiles();


        FileWriter fw = new FileWriter(file1, true);

        BufferedWriter bw = new BufferedWriter(fw);

        for (int i = 0; i < message.size(); i++) {

            bw.write(message.get(i));
            bw.newLine();
        }

        bw.close();
        fw.close();

        FileReader fr = new FileReader(file1);

        BufferedReader br = new BufferedReader(fr);

        fw = new FileWriter(file1, true);

        bw = new BufferedWriter(fw);

        while (br.ready()) {

            String line = br.readLine();

            System.out.println(line);

            bw.write(line);
            bw.newLine();

        }
        br.close();
        fr.close();

    } catch (IOException ex) {
        ex.printStackTrace();
        JOptionPane.showMessageDialog(null, "Error in" + ex);     
    }   
}

Você pode deixar um monte de recursos abertos. Esta é uma má prática, por favor, não faça isso.
Boris Brodski 27/04
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.