Java读取dbf文件

       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;
	}
		
 

 

你可能感兴趣的:(java)