Java读取txt文件和写入txt文件

2018-10-19更新

网友推荐更加简洁的写法,修改之后的代码;
项目实用优化,增加java7中的try-with-resources写法

package com.nickwong.code;

import java.io.*;

/**
 * Created by Nickwong on 31/07/2018.
 * 根据1-8楼的建议,优化了代码
 */
public class ReadTxt {

    public static void main(String args[]) {
        readFile();
        writeFile();
    }

    /**
     * 读入TXT文件
     */
    public static void readFile() {
        String pathname = "input.txt"; // 绝对路径或相对路径都可以,写入文件时演示相对路径,读取以上路径的input.txt文件
        //防止文件建立或读取失败,用catch捕捉错误并打印,也可以throw;
        //不关闭文件会导致资源的泄露,读写文件都同理
        //Java7的try-with-resources可以优雅关闭文件,异常时自动关闭文件;详细解读https://stackoverflow.com/a/12665271
        try (FileReader reader = new FileReader(pathname);
             BufferedReader br = new BufferedReader(reader) // 建立一个对象,它把文件内容转成计算机能读懂的语言
        ) {
            String line;
            //网友推荐更加简洁的写法
            while ((line = br.readLine()) != null) {
                // 一次读入一行数据
                System.out.println(line);
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    /**
     * 写入TXT文件
     */
    public static void writeFile() {
        try {
            File writeName = new File("output.txt"); // 相对路径,如果没有则要建立一个新的output.txt文件
            writeName.createNewFile(); // 创建新文件,有同名的文件的话直接覆盖
            try (FileWriter writer = new FileWriter(writeName);
                 BufferedWriter out = new BufferedWriter(writer)
            ) {
                out.write("我会写入文件啦1\r\n"); // \r\n即为换行
                out.write("我会写入文件啦2\r\n"); // \r\n即为换行
                out.flush(); // 把缓存区内容压入文件
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}


##参考原文: Java读取txt文件和写入txt文件##

写Java程序时经常碰到要读如txt或写入txt文件的情况,但是由于要定义好多变量,经常记不住,每次都要查,特此整理一下,简单易用,方便好懂!

    package edu.thu.keyword.test;  
      
    import java.io.File;  
    import java.io.InputStreamReader;  
    import java.io.BufferedReader;  
    import java.io.BufferedWriter;  
    import java.io.FileInputStream;  
    import java.io.FileWriter;  
      
    public class cin_txt {  
        static void main(String args[]) {  
            try { // 防止文件建立或读取失败,用catch捕捉错误并打印,也可以throw  
      
                /* 读入TXT文件 */  
                String pathname = "D:\\twitter\\13_9_6\\dataset\\en\\input.txt"; // 绝对路径或相对路径都可以,这里是绝对路径,写入文件时演示相对路径  
                File filename = new File(pathname); // 要读取以上路径的input。txt文件  
                InputStreamReader reader = new InputStreamReader(  
                        new FileInputStream(filename)); // 建立一个输入流对象reader  
                BufferedReader br = new BufferedReader(reader); // 建立一个对象,它把文件内容转成计算机能读懂的语言  
                String line = "";  
                line = br.readLine();  
                while (line != null) {  
                    line = br.readLine(); // 一次读入一行数据  
                }  
      
                /* 写入Txt文件 */  
                File writename = new File(".\\result\\en\\output.txt"); // 相对路径,如果没有则要建立一个新的output。txt文件  
                writename.createNewFile(); // 创建新文件  
                BufferedWriter out = new BufferedWriter(new FileWriter(writename));  
                out.write("我会写入文件啦\r\n"); // \r\n即为换行  
                out.flush(); // 把缓存区内容压入文件  
                out.close(); // 最后记得关闭文件  
      
            } catch (Exception e) {  
                e.printStackTrace();  
            }  
        }  
    }  
  • 184
    点赞
  • 811
    收藏
    觉得还不错? 一键收藏
  • 42
    评论
要将一个txt文件中的数据写入数据库,你需要完成以下步骤: 1. 创建数据库连接:使用DriverManager类的getConnection()方法创建一个数据库连接。此方法需要数据库的URL、用户名和密码等参数。 2. 打开txt文件:使用Java I/O操作打开txt文件,并读取其中的数据。 3. 将数据插入到数据库:使用PreparedStatement对象将读取的数据插入到数据库中。在插入数据之前,你需要为PreparedStatement对象设置SQL语句中的占位符(使用问号表示)并设置对应的参数。 4. 关闭连接:在完成所有操作之后,记得关闭数据库连接。 下面是一个简单的Java程序,演示了如何将txt文件中的数据写入MySQL数据库: ```java import java.io.BufferedReader; import java.io.FileReader; import java.sql.*; public class Main { public static void main(String[] args) { try { // 加载MySQL JDBC驱动程序 Class.forName("com.mysql.jdbc.Driver"); // 创建数据库连接 Connection conn = DriverManager.getConnection( "jdbc:mysql://localhost:3306/mydatabase", "username", "password"); // 打开txt文件 BufferedReader br = new BufferedReader(new FileReader("data.txt")); // 创建插入数据的PreparedStatement对象 String sql = "INSERT INTO mytable(name, age) VALUES(?, ?)"; PreparedStatement pstmt = conn.prepareStatement(sql); // 逐行读取txt文件并插入到数据库中 String line; while ((line = br.readLine()) != null) { String[] parts = line.split(","); String name = parts[0]; int age = Integer.parseInt(parts[1]); pstmt.setString(1, name); pstmt.setInt(2, age); pstmt.executeUpdate(); } // 关闭连接 pstmt.close(); conn.close(); br.close(); } catch (Exception ex) { ex.printStackTrace(); } } } ``` 在上面的代码中,你需要将数据库URL、用户名和密码替换为你自己的信息。此外,你需要将data.txt文件放在程序所在的目录下,并按照逗号分隔每一行的数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 42
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值