ReadImport

package com.legend;


import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.sql.SQLException;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;


import org.springframework.jdbc.core.support.JdbcDaoSupport;


import com.springTemplete123.ReadProperties;


public class ZipFileDemo extends JdbcDaoSupport {

public static void main(String[] args) throws Exception {
// ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
// ZipFileDemo dao = (ZipFileDemo) context.getBean("stuDao");
// dao.insert(ProcessCsv(importCsv(new File("D:/CSV.csv"))));
// ProcessCsv(importCsv(new File("D:/CSV.csv")));
new ZipFileDemo().MakeDir(new ZipFileDemo().ReadProperties());
}

// 对读取的csv 数据进行解析放入 Bean对象的方法
public static List<StudentBean> ProcessCsv(List<String> list) throws ParseException{
int i = 0;  // 计数器,初始值为0,因为csv的表头是不需要插入到DB里的,所以当为0时,不做任何
List<StudentBean> stuList = new ArrayList<StudentBean>();
StudentBean stu1 = new StudentBean();
       if(list!=null && !list.isEmpty()){
           for(String data : list){
           
               System.out.println(data);
               String dataBean[] = data.split(",");
               if (i == 0) {
//                 new SimpleDateFormat("yyyyMMdd").format(dataBean[0]);
                stu1.setEffective_date(new SimpleDateFormat("yyyyMMdd").parse(dataBean[0]));
}
                if (i == 1) {
                i++;
}
                if (i >= 3 ) {
                stu1.setId(Integer.parseInt(dataBean[0].trim()));   // id为int, 所以要讲数组为1的转成int
                stu1.setName(dataBean[1].trim());
                stu1.setAge(Integer.parseInt(dataBean[2].trim()));
                stu1.setSex(dataBean[3].trim());
                stuList.add(stu1);
}
                i++;
           }
       }
return stuList;
}

//写入到数据库的方法
public void insert(List<StudentBean> list) {
for (StudentBean studentBean : list) {
String sql = "insert into student(effective_date,id,name,age,sex) values(?,?,?,?,?)";
this.getJdbcTemplate().update(sql,studentBean.getEffective_date(),studentBean.getId(),studentBean.getName(),studentBean.getAge(),studentBean.getSex());
}
}

//拿到Effative_date 不管数据库是否有,都删除的方法
public void deleteStu(int id)  throws SQLException{
try {
if (id != 0) {
String sql = "delete from student where id=?";
this.getJdbcTemplate().update(sql, id);
}
} catch (Exception e) {
e.printStackTrace();
}

}

// 读取数据的方法
public static List<String> importCsv(File file){
       List<String> dataList=new ArrayList<String>();
       
       BufferedReader br=null;
       try { 
           br = new BufferedReader(new FileReader(file));
           String line = ""; 
           while ((line = br.readLine()) != null) { 
               dataList.add(line);
           }
       }catch (Exception e) {
        e.printStackTrace();
       }finally{
           if(br!=null){
               try {
                   br.close();
                   br=null;
               } catch (IOException e) {
                   e.printStackTrace();
               }
           }
       }
       System.out.println(dataList);
       return dataList; 
   }
//创建文件目录
public void MakeDir(String url) {
File file = new File(url);
if (!file.exists()) {
System.out.println("文件夹不存在");
}else {
System.out.println("文件夹存在");
}
file.mkdirs(); // 创建的文件夹会在当前项目的根目录下创建
}
 
// 读取properties文件的 路径
public String ReadProperties() throws IOException {
Properties prop = new Properties();
prop.load(ReadProperties.class.getClassLoader().getResourceAsStream("a.properties"));
String url = prop.getProperty("pathName"); // 获取properties属性
return url; 
}
 
//获取当前project的路径
public String getPath() {
return Thread.currentThread().getContextClassLoader().getResource("").getPath();
}
 
}
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READme.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值