ITPub博客

首页 > Linux操作系统 > Linux操作系统 > [转载]通过文本文档实现信息的批量导入

[转载]通过文本文档实现信息的批量导入

原创 Linux操作系统 作者:dinner1007 时间:2019-04-11 08:36:08 0 删除 编辑
通过文本文档实现信息的批量导入
最近参与了一个网上直报项目的维护工作,该网上直报应用程序有一个功能就是通过导入文本文档的方式向后台数据库中批量导入直报用户,包括用户各项信息如单位名称、企业资质等级等等。其核心之处就是如何获取所上载文本文档中的内容,现将该部分程序简单介绍如下:

首先是后台的javabean程序如下所示:

package Util;

import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import java.util.LinkedList;
import java.io.*;

public class ReadRequest{
public LinkedList getRequest(HttpServletRequest request){
LinkedList output=new LinkedList();
try{
ServletInputStream in=request.getInputStream();
int len=request.getContentLength();
System.out.println (len);
byte []b=new byte[len];
in.read(b,0,len);
String str=new String(b);
System.out.println (str);
BufferedReader con=new BufferedReader(new StringReader(str));
String c="";
while((c=con.readLine())!=null){
output.add(c);
}
}
catch(Exception e){e.printStackTrace();}
return output;
}
}

然后是写相应的jsp测试页面,此页面没有经过美工处理,仅为测试之用:)。

index.jsp

<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %>
http://www.w3.org/TR/html4/loose.dtd">

<%----%>
<%@ page import="java.util.*"%>



测试





<%
LinkedList output=new LinkedList();
output=pn.getRequest(request);
//output=pn.readHttpData(request);
System.out.println(output.size());
for(int i=0;i out.println(output.get(i)+"
");
}
%>


这样就会输出文档中的内容来了,当然还有一些其他的内容,可根据实际需要对内容进行处理。需要注意的是,在该网上直报程序中,文档的格式是有要求的,每行 为一个公司的基本信息,各个属性之间用“,”隔开(也可以是其他的符号如“@”),并且各个属性出现的顺序也是固定的(如必须第一项是法人代码,第二项是 公司名称)。得到了文档中的内容后,就可以用一个循环批量的插入用户信息了。比如说,我上载的文本文档内容如下所示:

300000000,武汉,420101,230,A304,A211,4700
300000001,武汉,420101,230,A304,A211,4700
300000002,武汉,420101,230,A304,A211,4700
300000003,武汉,420101,230,A304,A211,4700
首 先对output进行处理,把前面的http头内容如:Content-Disposition: form-data; name="sdf"; filename="C:Documents and Settingsyy桌面 est_jz.txt"以及尾remove掉,现在的output就只有文档中的内容了。然后就开始插入数据库(只给出 代码片断):

//以下代码仅适合本人的例子,具体情况具体而定

for(int i=0;i if (output.get(i) == null || ( (String) output.get(i)).equals("")) {
continue; //空行则自动换行 }
String s = (String) output.get(i); //取得一行 String[] ss = s.split(",");
String sql="insert into xt_user(f001,f002,f003,f004,f005,f006) values(?,?,?,?,?,?)";
PreparedStatement ps=con.prepareStatement(sql);
ps.setString(1,ss[0]);
ps.setString(2,ss[1]);
ps.setString(3,ss[2]);
ps.setString(4,ss[3]);
ps.setString(5,ss[4]);
ps.setString(6,ss[5]);
ps.executeUpdate();
}

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/374079/viewspace-131091/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2018-08-23

  • 博文量
    698
  • 访问量
    485828