用java代码实现读取一个文件中所以的txt文件逐行读取txt文件中的内容清除所以空格和换行,判断如果等于字符串[INTRO]时,之后的读取内容方式改为两行读取内容,内容不能为空格和换行,如果等于字符串优待政策时,就改为多行读取,结束标记为服务设施,如果等于字符串服务设施时,就改为多行读取,结束标记为[GRADE],如果等于字符串[GRADE]时,就按照逐行读取内容,最后将这些数据放入数据库中

时间: 2024-03-14 11:47:35 浏览: 20
以下是Java代码的实现: ```java import java.io.BufferedReader; import java.io.File; import java.io.FileReader; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; public class FileParser { public static void main(String[] args) { File file = new File("file.txt"); // 读取的文件名 try { BufferedReader reader = new BufferedReader(new FileReader(file)); String line; String type = ""; // 当前读取的类型 String content = ""; // 当前读取的内容 String prevLine = ""; // 上一行读取的内容 while ((line = reader.readLine()) != null) { line = line.trim(); // 去除前后空格 if (line.equals("[INTRO]")) { type = "INTRO"; prevLine = line; } else if (line.equals("优待政策")) { type = "POLICY"; prevLine = line; } else if (line.equals("服务设施")) { type = "SERVICE"; prevLine = line; } else if (line.equals("[GRADE]")) { type = "GRADE"; prevLine = line; } else { if (type.equals("INTRO")) { if (!line.isEmpty()) { // 判断内容不为空 if (prevLine.equals("[INTRO]")) { // 按两行读取 content = line; prevLine = line; } else { content += line; prevLine = line; } } } else if (type.equals("POLICY")) { if (!line.isEmpty()) { // 判断内容不为空 if (prevLine.equals("优待政策")) { // 按多行读取 content = line; prevLine = line; } else { content += "\n" + line; prevLine = line; } } if (line.equals("服务设施")) { // 结束标记 saveToDatabase(type, content); // 保存到数据库 type = ""; content = ""; } } else if (type.equals("SERVICE")) { if (!line.isEmpty()) { // 判断内容不为空 if (prevLine.equals("服务设施")) { // 按多行读取 content = line; prevLine = line; } else { content += "\n" + line; prevLine = line; } } if (line.equals("[GRADE]")) { // 结束标记 saveToDatabase(type, content); // 保存到数据库 type = ""; content = ""; } } else if (type.equals("GRADE")) { if (!line.isEmpty()) { // 判断内容不为空 content = line; saveToDatabase(type, content); // 直接保存到数据库 content = ""; } } } } reader.close(); } catch (Exception e) { e.printStackTrace(); } } private static void saveToDatabase(String type, String content) { // 将数据保存到数据库 Connection conn = null; PreparedStatement ps = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password"); String sql = "INSERT INTO data(type, content) VALUES (?, ?)"; ps = conn.prepareStatement(sql); ps.setString(1, type); ps.setString(2, content); ps.executeUpdate(); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } finally { try { if (ps != null) ps.close(); if (conn != null) conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } } ``` 这段代码可以读取文件中的内容,并根据不同的类型进行不同的读取方式。读取到的内容会被保存到数据库中。需要注意的是,保存到数据库的代码中的数据库连接信息、表名、字段名等需要根据实际情况修改。

最新推荐

recommend-type

python_geohash-0.8.5-cp38-cp38-win_amd64.whl.zip

python_geohash-0.8.5-cp38-cp38-win_amd64.whl.zip
recommend-type

ascii码表所有汇总

ascii码表 ASCII(发音:,American Standard Code for Information Interchange,美国信息交换标准代码)是基于拉丁字母的一套电脑编码系统。它主要用于显示现代英语,而其扩展版本延伸美国标准信息交换码则可以部分支持其他西欧语言,并等同于国际标准ISO/IEC 646。 ASCII 由电报码发展而来。第一版标准发布于1963年 ,1967年经历了一次主要修订[5][6],最后一次更新则是在1986年,至今为止共定义了128个字符;其中33个字符无法显示(一些终端提供了扩展,使得这些字符可显示为诸如笑脸、扑克牌花式等8-bit符号),且这33个字符多数都已是陈废的控制字符。控制字符的用途主要是用来操控已经处理过的文字。在33个字符之外的是95个可显示的字符。用键盘敲下空白键所产生的空白字符也算1个可显示字符(显示为空白)。
recommend-type

星途追风1.6T 车机升级包

适合零件号 703000731AA和703000617AA使用
recommend-type

scratch2源码直升机大战

scratch2源码直升机大战提取方式是百度网盘分享地址
recommend-type

谷歌浏览器 windows 2012

谷歌浏览器 windows 2012 32位
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

get() { return this.photoState },

这是一个 JavaScript 中的方法定义,它定义了一个名为 `get` 的方法。这个方法没有参数,它返回了 `this.photoState`。在这个方法中,`this` 是指当前对象,而 `photoState` 是该对象的一个属性。通常情况下,`get` 方法用于获取对象的属性值,并且可以在获取属性值之前进行一些逻辑操作。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。