java操作dbf文件Api提供组织:http://sarovar.org/projects/javadbf/但是到2004年该组织停止了javadbf 的更新。并且对中文的支持也不够好,后来参照一哥们的提示,修改了其中的方法,中文不在乱码,也不会在读取的时候丢失数据,根据我的认识,我对这一过程做一总结。需要重新编译后包或交流的哥们可加我QQ:18042005836
操作dbf文件的步骤是从本地上传到服务器,然后在从中获取数据,下面方法就是从dbf文件中获取数据,将数据封装到List中返回。在插入数据库中。
public List<String[]> getFileData(String uploadFileName, String tableName,String[] index) {
DBFReader reader=null;//从dbf中获取内容
List<String[]> list=new LinkedList<String []>();
String[] array=null;
try {
InputStream in=new FileInputStream(new File(temp+"\\"+uploadFileName));
reader=new DBFReader(in);//将文件从文件流中读入。
int fcount=reader.getFieldCount();//读取字段个数
int rowNo=reader.getRecordCount();//获取有多少条记录
int length=index.length;//为其他地方获得列宽度,这里可忽略
int[] colIndex=new int[length];//设置列的数量。
for(int i=0;i<length;i++){
colIndex[i] = DBUtils.toInteger(index[i]);//将传入的列名赋值给新列
}
for(int j=0;j<reader.getFieldCount();j++){//dbf 貌似必须指定列的宽度大小
reader.getField(j).setFieldLength(reader.getField(j).getFieldLength());
}
Object []rowObjects;//获取一个文件的行数
while((rowObjects = reader.nextRecord())!=null){
array=new String[rowObjects.length];//array为新dbf每一行的所有值数组。
for(int i=0;i<fcount;i++){
String s=rowObjects[i].toString().trim();
if(s.equals("")||s==null||s.length()<=0||s.isEmpty()||"null".equals(s)){
array[i]= "";
}else{
array[i]=s;
}
}
list.add(array);
}
}
catch (FileNotFoundException e) {
log.error("解析dbf数据过程中,没有找到dbf文件");
e.printStackTrace();
} catch (DBFException e) {
log.error("解析dbf数据过程中,dbf文件读取异常");
e.printStackTrace();
}
return list;
}
分享到:
相关推荐
dbf-jdbc-wisecoders,JAVA 读写DBF文件工具包
java读取dbf文件,整套代码放到工程下能直接运行看到代码
Java读取DBF文件jar包以及测试用例 Java读取DBF文件jar包以及测试用例
Java读取DBF文件jar包javadbf.jar,像高考分数一般导出都是dbf文件。
Java读取DBF文件jar包以及测试用例
使用Java实现对dbf文件的简单读写.
包括java读写dbf文件源码,可改写重用,可用于生成dbf文件或解析dbf文件获取数据。
免费资源大家共享
用java解析dbf文件,三种方法,一种按行解析,另两种是要把dbf当做一个表来进行操作就像查询一样 解析驱动是把dbf文件当做表来解析,两种方法中其中一种要装驱动,另一种不要装,这取决你的dbf文件的格式
用JavaDBF操作(读、写)DBF文件
封装了大数据DBF的读取、写入,并附有所使用javadbf.jar文件
java 实现DBF文件读取与创建
使用Java NIO 包下的RandomAccessFile读取DBF文件(可以拓展到多线程读取大文件)
主要介绍了java通过javadbf读取和生成DBF文件的方法,大家参考使用吧
Java解析某些DBF文件时喜欢出错误,错误一:Failed to parse Number: For input string: "-.---" , 错误二:有时候有些被标记为删除的数据读取不出来,已打成jar包
Java下读写DBF数据库文件格式研究.pdf
DBF文件读取的类,用于读取一般的DBF格式文件
该项目包含了项目所需要的jar包以及测试案例。项目使用环境为eclipse jdk1.8 1.poi.Testpoi为测试用例;...3.解决了javadbf读取dbf文件表头和数据乱码问题,com.webadmin.util.dbf.DBFReaderTest为测试用例。
JAVA直接连接access数据库dbf文件,同时兼容LINUX、UNIX、WINDOWS操作系统。示例工程代码,导入eclipse即可运行。
读取shp文件的代码,也可以读DBF属性