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;
}
java 读取dbf文件
最新推荐文章于 2022-04-24 22:41:43 发布