ReadImport

来源:互联网 发布:天天炫斗刷钻石软件 编辑:程序博客网 时间:2024/06/07 01:41
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();
}
 
}
0 0
原创粉丝点击