Java按行 读取/修改 文件

import java.io.File;
import java.io.IOException;
import java.io.RandomAccessFile;
import java.util.Arrays;

/**
 * @author :dage
 * @description :
 * @date : 2019/7/29 16:48
 */
public class Test {
    public static void main(String[] args){
        try {
            File file = new File("F:\\关联表.sql");
            RandomAccessFile fileR = new RandomAccessFile(file,"r");
            // 按行读取字符串
            String str = null;
            while ((str = fileR.readLine())!= null) {
                    if(str.startsWith("values") ){
                        str = new String(str.getBytes("8859_1"), "gbk");
                        str.replaceAll("'","");
                        System.out.println(str);
                        String[]strArr = str.split(",");
                        String userId = strArr[0].replace("values (","");
                        String realName = strArr[1];
                        String sex = strArr[2].replace("'","");
                        String birthday = strArr[3]+","+strArr[4];
                        String idtype = strArr[5].replace("'","");
                        String idno = strArr[6];

                        StringBuilder  sb = new StringBuilder() ;
                        sb.append("update pf_customer set user_id = ").append(userId).append(" where real_name =").append(realName)
                                .append(" and sex =").append(sex).append("  and idtype =").append(idtype).append(" and idno =").append(idno)
                                .append(" and birthday =").append(birthday).append("\n");
                        write(sb.toString());
                        System.out.println(sb.toString());
                    }

               // break;
            }
            fileR.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
        //

    }
	//按行写入
    public static void write(String data) throws IOException {
        //读写的数据源
        File f = new File("F:\\data.sql");
        //指定文件不存在就创建同名文件
        if(!f.exists())    f.createNewFile();
        //rw : 设为读写模式
        RandomAccessFile raf = new RandomAccessFile(f,"rw");
        System.out.println("当前记录指针位置:" + raf.getFilePointer());
        //记录指针与文件内容长度相等
        raf.seek(raf.length());
        System.out.println("当前文件长度:" + raf.length());
        //以字节形式写入字符串
        raf.write(data.getBytes());
        System.out.println("当前记录指针位置:" + raf.getFilePointer());
    }




    }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值