springboot解析txt文件顺便加到数据库中(nohup文件)

简介: springboot解析txt文件顺便加到数据库中(nohup文件)


现在是:2022年4月20日13:33:23

以前是怎么都没想到,我需要在服务器的nohup文件中找记录,然后往数据库里面更新。具体因为啥不提了,说多了都是愧啊~今天主要是分享一个java解析nohup文件提取关注的信息,然后添加到数据库中。

实现思路

刚开始我是直接将nohup文件中的信息手动复制出来,然后写了个insertsql语句,一条一条的往里面添加,结果发现有上千条,这么干不睡觉都加不进去多少,于是想到了找小杨小于帮帮忙,无奈有点复杂,光给他两讲怎么加讲了半天,还不能保证他两会了,数据能加对。。。。。

后来想了个办法,将nohup文件先转换成txt文件,然后解析txt文件,根据关键字提取关键信息,拿到之后截取成固定字符串,通过jdbc的方式添加在数据库中。

  1. nohup文件的后缀改成txt
  2. 观察自己关注的数据的规律,尤其是前后有什么可以标识的,看了看,可以根据Parameters这个来解析。

  1. 因为很不规律,所以有单独查找了下(Timestamp),截取成一个字符串
  2. 本来想着按照逗号来将这个字符串中所有需要的信息截取到,依次添加到数据库中,结果发现有个字段是介绍,里面的值也有逗号,有中文的逗号,也有因为的逗号,这种方法看来行不通。
  3. 想办法查找(Stirng),全文替换成~,然后按照~查找,最后在截取,终于可行了。

实现代码

1.按照Parameters解析txt文件:

package com.ruoyi.web.controller.util;  import com.ruoyi.system.domain.EquipmentRZ;  import java.io.File;  import java.io.FileNotFoundException;  import java.text.ParseException;  import java.text.SimpleDateFormat;  import java.util.Scanner;  /**  * @author: muxiongxiong  * @date: 2022年04月19日 上午 11:05  * 公众号:雄雄的小课堂  * 博客:https://blog.csdn.net/qq_34137397  * 个人站:http://www.穆雄雄.com  * 个人站:http://www.muxiongxiong.cn  * @Description: 解析txt文件获取里面的数据  * 最初解析的是nohup文件,现在改为解析txt文件  * 将txt文件里面的内容,解析成对象,添加到认证器材表里去  */  public class ParseTXTFileUtils {  public void parseTxt(){  File file = new File("D:\\test3.txt");  SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  if (!file.exists()) {  System.out.println("节点基本信息文件未找到");  }  Scanner s = null;  try {  s = new Scanner(file);  } catch (FileNotFoundException e) {  e.printStackTrace();  }  while (true) {  //文档中的内容  String danci = s.next();  if ("Parameters:".equals(danci)) {  //开始留存需要的数据.  String jixu = "";  int count = 0;  while (true) {  EquipmentRZ equipmentRZ = new EquipmentRZ();  String danci2 = s.next();  jixu += danci2;  if (danci2.indexOf("Timestamp") != -1) {  String sheng = s.next();  String shi = s.next();  String qu = s.next();  String renzheng = s.next();  String tupian = s.next();  String jieshuriqi = s.next();  jixu += sheng + shi + qu + renzheng + tupian + jieshuriqi;  //System.out.println("jixu========"+jixu);  //按照逗号分割  String[] split = jixu.split("~,");  //获取到的数据  try {  equipmentRZ.setId(Integer.parseInt(split[0]));  equipmentRZ.setName(split[1]);  equipmentRZ.setXinghao(split[2]);  equipmentRZ.setJianjie(split[3]);  equipmentRZ.setZhuangtai(split[4]);  equipmentRZ.setGongsi1(split[5]);  equipmentRZ.setGongsi2(split[6]);  equipmentRZ.setRealName(split[7]);  equipmentRZ.setLeixing(split[8]);  equipmentRZ.setGongsi3(split[9]);  //2016-11-3011:35:08.0(Timestamp),天津市  String shijian = split[10];  //按照逗号分割  String[] split1 = shijian.split(",");  //截取最后的(Timestamp)  int index = split1[0].lastIndexOf("(");  String kaishishijian = split1[0].substring(0, index);  //第9位后面加上空格  StringBuffer sb = new StringBuffer(kaishishijian);  sb.insert(10, " ");  equipmentRZ.setBeginDate(simpleDateFormat.parse(sb.toString()));  equipmentRZ.setSheng(split1[1]);  equipmentRZ.setShi(split[11]);  equipmentRZ.setJiedao(split[12]);  equipmentRZ.setRenzheng(split[13]);  equipmentRZ.setTupian(split[14]);  String jieshu = split[15] + " 00:00:00";  equipmentRZ.setEndDate(simpleDateFormat.parse(jieshu));  //System.out.println(equipmentRZ);  } catch (ParseException e) {  e.printStackTrace();  }  //调佣添加的方法 将数据添加到数据库  //已经执行完毕 2022年4月19日11:08:54  /* ZhiXingMysql zhiXingMysql = new ZhiXingMysql();  zhiXingMysql.saveEquipmentRZ(equipmentRZ);*/  break;  }  }  }  }  } }

2.由于字段太多了,所以封装了个实体类,字段如下:

/**  * @author: muxiongxiong  * @date: 2022年04月19日 0:25  * 公众号:雄雄的小课堂  * 博客:https://blog.csdn.net/qq_34137397  * 个人站:http://www.穆雄雄.com  * 个人站:http://www.muxiongxiong.cn  * @Description: 类的描述  */ public class EquipmentRZ {  private Integer id;  private String name;  private String xinghao;  private String jianjie;  private String zhuangtai;  private String gongsi1;  private String gongsi2;  private String gongsi3;  private String realName;  private String leixing;  private Date beginDate;  private String sheng;  private String shi;  private String jiedao;  private String tupian;  private String renzheng;  private Date endDate;  }

3.jdbc添加到数据库中的方法:

public void saveEquipmentRZ(EquipmentRZ equipmentRZ) {  int success = 0,err=0;  String sql = "INSERT INTO sys_rzequipment ( equipment_id,equipment_name, equipment_model, equipment_introduction,equipment_status, production_name, maintenance_name, installation_company_name,maintenance_people, equipment_type, installation_date, installation_province, installation_city, installation_address, equipment_img_url, create_time,date_come_from ) \n" +  "VALUES(?,?,?,?,?,?,?, ?,?,?,?,?,?,?,?,?,?)";  Connection connection = null;  PreparedStatement pStatement = null;  try {  connection = getConnection();  pStatement = connection.prepareStatement(sql);  pStatement.setInt(1, equipmentRZ.getId());  pStatement.setString(2, equipmentRZ.getName());  pStatement.setString(3, equipmentRZ.getXinghao());  pStatement.setString(4, equipmentRZ.getJianjie());  pStatement.setString(5, equipmentRZ.getZhuangtai());  pStatement.setString(6, equipmentRZ.getGongsi1());  pStatement.setString(7, equipmentRZ.getGongsi2());  pStatement.setString(8, equipmentRZ.getGongsi3());  pStatement.setString(9, equipmentRZ.getRealName());  pStatement.setString(10, equipmentRZ.getLeixing());  pStatement.setObject(11, equipmentRZ.getBeginDate());  pStatement.setString(12, equipmentRZ.getSheng());  pStatement.setString(13, equipmentRZ.getShi());  pStatement.setString(14, equipmentRZ.getJiedao());  pStatement.setString(15, equipmentRZ.getTupian());  pStatement.setObject(16, equipmentRZ.getEndDate());  pStatement.setString(17, equipmentRZ.getRenzheng());  int count = pStatement.executeUpdate();  if(count>0){  success++;  System.out.println("成功:"+success+"==="+equipmentRZ.getId());  }else{  err++;  System.out.println("失败:"+err+"===="+equipmentRZ.getId());  }  } catch (Exception e) {  e.printStackTrace();  } finally {  closePreparedStatement(pStatement);  closeConnection(connection);  }  }

最后运行main方法就可以了。、

注意事项

  • 为了保险起见,刚开始测试的时候测试添加的数据尽量的少点儿,也就是将txt重新复制出来一份,只留几条记录,执行一遍main方法,观察一下数据库中的数据是否正确。
  • 执行的过程中可能会遇到错误,因为Parameters可能在登录操作的时候也会出现,所以遇到不是添加的sql的话,也会报错的,只需要将原来执行过的删掉,不规则的Parameters数据在txt文件中删掉继续执行即可。
相关文章
|
2月前
|
人工智能 Java 开发者
【Spring】原理解析:Spring Boot 自动配置
Spring Boot通过“约定优于配置”的设计理念,自动检测项目依赖并根据这些依赖自动装配相应的Bean,从而解放开发者从繁琐的配置工作中解脱出来,专注于业务逻辑实现。
|
29天前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
1月前
|
XML JSON Java
【SpringBoot(三)】从请求到响应再到视图解析与模板引擎,本文带你领悟SpringBoot请求接收全流程!
Springboot专栏第三章,从请求的接收到视图解析,再到thymeleaf模板引擎的使用! 本文带你领悟SpringBoot请求接收到渲染的使用全流程!
167 3
|
2月前
|
Java 数据库 数据安全/隐私保护
Spring Boot四层架构深度解析
本文详解Spring Boot四层架构(Controller-Service-DAO-Database)的核心思想与实战应用,涵盖职责划分、代码结构、依赖注入、事务管理及常见问题解决方案,助力构建高内聚、低耦合的企业级应用。
690 1
|
2月前
|
缓存 Java 应用服务中间件
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
本文详解Spring Boot十大核心配置优化技巧,涵盖Tomcat连接池、数据库连接池、Jackson时区、日志管理、缓存策略、异步线程池等关键配置,结合代码示例与通俗解释,助你轻松掌握高并发场景下的性能调优方法,适用于实际项目落地。
479 5
|
7月前
|
前端开发 安全 Java
Spring Boot 便利店销售系统项目分包设计解析
本文深入解析了基于Spring Boot的便利店销售系统分包设计,通过清晰的分层架构(表现层、业务逻辑层、数据访问层等)和模块化设计,提升了代码的可维护性、复用性和扩展性。具体分包结构包括`controller`、`service`、`repository`、`entity`、`dto`、`config`和`util`等模块,职责分明,便于团队协作与功能迭代。该设计为复杂企业级应用开发提供了实践参考。
275 0
|
4月前
|
前端开发 Java 数据库连接
SpringBoot参数校验底层原理和实操。深度历险、深度解析(图解+秒懂+史上最全)
SpringBoot参数校验底层原理和实操。深度历险、深度解析(图解+秒懂+史上最全)
SpringBoot参数校验底层原理和实操。深度历险、深度解析(图解+秒懂+史上最全)
|
4月前
|
机器学习/深度学习 XML Java
【spring boot logback】日志logback格式解析
在 Spring Boot 中,Logback 是默认的日志框架,它支持灵活的日志格式配置。通过配置 logback.xml 文件,可以定义日志的输出格式、日志级别、日志文件路径等。
694 5
|
4月前
|
Java 关系型数据库 数据库连接
Spring Boot项目集成MyBatis Plus操作PostgreSQL全解析
集成 Spring Boot、PostgreSQL 和 MyBatis Plus 的步骤与 MyBatis 类似,只不过在 MyBatis Plus 中提供了更多的便利功能,如自动生成 SQL、分页查询、Wrapper 查询等。
371 3
下一篇