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

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

首先是后台的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


ttp://www.w3.org/TR/html4/loose.dtd">http://www.w3.org/TR/html4/loose.dtd">

--%>




测试





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/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/374079/viewspace-131091/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值