A. 如何讀取.dbf文件
對於dbf是什麼文件,我想一些朋友都不太注意,因為接觸的很少,除非是一些整天編程的朋友,或者是一些專 門 研究相關文件的朋友才會有所關注。簡單地講DBF就是一個格式,這個格式是存儲數據用的,因此dbf文件也叫做資料庫格式文件。
一、 dbf格式的來源
到底哪些軟體會應用到這樣的格式呢?像Foxbase,Dbase,Visual FoxPro等這些資料庫的處理系統都會需要這種格式的文件。也可以這么說,DBF格式的資料庫類型是我們經常會用到的一種桌面型的資料庫模式。它是一種結構化的標准格式,主要適用於數據存取的功能,在商業裡面應用的比較多一些。
dbf是什麼文件?它對於各個企業的關系是怎樣的呢?其實這種格式文件是數據交換工具,被廣泛的在各企業以及各個事業單位裡面使用。
二、dbf文件的讀取
那麼我們如何讀取這樣的文件呢?DBFViewerPlus1.67,DBF表查看器,這個軟體可以很好的很方便的查看以及編輯相關的DBF文件。這個軟體能夠輕而易舉的搜索以及篩選資料庫裡面的欄位值。此外除了這一款軟體之外,還有DataBaseBrowser資料庫瀏覽器。這個軟體也是可以查詢資料庫資料的一種工具類的軟體。它既可以讓我們看到資料庫的結構,也可以讓我們查看到相關的數據。此外一些資料庫信息,表索引也可以查看得到。
打開這類dbf文件我們也可以用excel打開,ACCESS也能夠打開這類資料庫文件。
B. java如何輸入輸出DBF格式文件
我建議用Microsoft Access建庫,導入數據為表,修改庫結構(欄位)屬性,再導出DBF文件!另外還有一個比較好的的方法: 打開 FOXPRO,選擇開始菜單中的導入,就可以了,資料庫結構不用修改
C. java如何操作DBF文件
ml頁面的一個鏈接中。這樣做的缺點是把文件在伺服器上的路徑暴露了,並且還無法對文件下載進行其它的控制(如許可權)。這個就不寫示例了。
2.在伺服器端把文件轉換成輸出流,寫入到response,以response把文件帶到瀏覽器,由瀏覽器來提示用戶是否願意保存文件到本地。(示例如下)
<%
response.setContentType(fileminitype);
response.setHeader("Location",filename);
response.setHeader("Cache-Control", "max-age=" + cacheTime);
//filename應該是編碼後的(utf-8)
response.setHeader("Content-Disposition", "attachment; filename=" + filename);
response.setContentLength(filelength);
OutputStream outputStream = response.getOutputStream();
InputStream inputStream = new FileInputStream(filepath);
byte[] buffer = new byte[1024];
int i = -1;
while ((i = inputStream.read(buffer)) != -1) {
outputStream.write(buffer, 0, i);
}
outputStream.flush();
outputStream.close();
inputStream.close();
outputStream = null;
%>
3.既然是JSP的話,還有一種方式就是用Applet來實現文件的下載。不過客戶首先得信任你的這個Applet小程序,由這個程序來接受由servlet發送來的數據流,並寫入到本地。
servlet端示例
public void service(HttpServletRequest req, HttpServletResponse res)
throws ServletException, IOException {
res.setContentType(" text/plain ");
OutputStream outputStream = null;
try {
outputStream = res.getOutputStream();
//把文件路徑為srcFile的文件寫入outputStream中
popFile(srcFile, outputStream)) ;
} catch (IOException e) {
e.printStackTrace();
}
}
JApplet端示例
URLConnection con;
try {
//url是被調用的SERVLET的網址 如 *.do
con = url.openConnection();
con.setUseCaches(false);
con.setDoInput(true);
con.setDoOutput(true);
con.setRequestProperty("Content-Type",
"application/octet-stream");
InputStream in = con.getInputStream();
ProgressMonitorInputStream pmInputStream = new ProgressMonitorInputStream
(pane, "正在從伺服器下載文件內容", in);
ProgressMonitor pMonitor = pmInputStream.getProgressMonitor();
pMonitor.setMillisToDecideToPopup(3);
pMonitor.setMillisToPopup(3);
//localfilepath本地路徑,localstr文件文件夾,filename本地文件名
String localfilepath = localstr + filename ;
//方法saveFilsaveFilee是把輸入流pmInputStream寫到文件localfilepath中
if(saveFilsaveFilee(localfilepath,pmInputStream)){
openLocalFile(localfilepath);
}
4.順便把JApplet上傳文件的代碼也貼上來.
JApplet端示例
URLConnection con;
try {
con = url.openConnection();
//url是被調用的SERVLET的網址 如 *.do
con.setUseCaches(false);
con.setDoInput(true);
con.setDoOutput(true);
con.setRequestProperty("Content-Type","application/octet-stream");
OutputStream out = con.getOutputStream();
//localfilepath本地路徑,localstr文件文件夾,filename本地文件名
String localfilepath = localstr + filename;
//文件getOutputStream是把文件localfilepath寫到輸出流out中
getOutputStream(localfilepath,out);
InputStream in = con.getInputStream();
return true;
}catch (IOException e) {
System.out.println("文件上傳出錯!");
e.printStackTrace();
}
servlet端代碼示例
public void service(HttpServletRequest req, HttpServletResponse res)
throws ServletException, IOException {
res.setContentType(" text/plain ");
InputStream inputStream = null;
try {
inputStream = res.getInputStream();
//把輸入流inputStream保存到文件路徑為srcFile的文件中
writefile(srcFile, inputStream);
} catch (IOException e) {
e.printStackTrace();
}
} // end service
總結:在文件的傳輸中是流的形式存在的,在硬碟上是文件的形式存在的。我們要做的只是通過HttpServletRequest和HttpServletResponse,或者是response和request來發送流和讀取流。以及把文件轉換成流或把流轉換成文件的操作。
D. java.sql.SQLException: [Microsoft][ODBC 驅動程序管理器] 未發現數據源名稱並且未指定默認驅動程序
只能是驅動有問題 ,可能是驅動不兼容,
E. java連接dbf,執行sql語句的時候提示找不到文件,請看
通過看你寫的代碼中發現,驅動已經找到,並且數據也連接正常,請檢查表是否存在,你打開資料庫看下,是不是有這個表。
F. java本身可以讀取什麼文件
文件流。或者是通過代碼編寫,可以讀取大部分的外部文件。
如果想要讀取機器中的東西,需要做詳細的code才行。
G. java讀取dbf文件時,程序跑到dbfreader.nextRecord();時報錯com.linuxense.javadbf.DBFException: Failed
應該是 字元串解析成數值型出錯吧。 你可以看看dbf文件里的內容是否有問題。
H. java解析dbf格式時裡面數據類型怎麼判斷
使用JDBC-ODBC橋接方式讀取Access文件,使用Acces
與DBF都需要配置橋接模式,在控制面板里,選擇管理工具里配置
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");//載入驅動
try{
//conn=DriverManager.getConnection(DB_URL);
conn=DriverManager.getConnection("jdbc:odbc:ss","test.dbf","");//無密碼則空字元串
pstm=conn.prepareStatement("select*fromtest");//此處的XXB為DBF數據文件的名字
rs=pstm.executeQuery();
至此,完美解決DBF資料庫文件讀取。網上的東西,太雜了,所以,我們要理智判斷,取其精華,去其糟粕,為我所用。
終於被我找到了!
完全free的: com/ 這個網站主要是做資料庫連接中間介的,其中用到了一個他們自己開發的叫做JDBF的項目,該項目就是專門控制dbf文件的,整個包只有30K大小,你們隨便用個工具反編譯一下就可以看懂裡面的代碼,很簡單,就是按照具體格式處理文件!(注意,不是使用JDBC連接的。)
不過我試了一下,發現只支持三中格式的:foxpro2.x、DBase IV、DBase III。
大家用得著的話可以去那裡下載! 有問題的話可以再來問我。
我發現國外的這類開源網站很多,國內的就少得可憐了!唉!
I. 如何用java操作.dbf資料庫
1.引入javadbf.4.1.jar
2.
import com.linuxense.javadbf.DBFField;
import com.linuxense.javadbf.DBFReader;
3.實例
package com.realhope.jdbf;
import java.io.FileInputStream;
import java.io.InputStream;
import com.linuxense.javadbf.DBFField;
import com.linuxense.javadbf.DBFReader;
public class readDBF {
public static void readDBF(String path) {
InputStream fis = null;
try {
// 讀取文件的輸入流
fis = new FileInputStream(path);
// 根據輸入流初始化一個DBFReader實例,用來讀取DBF文件信息
DBFReader reader = new DBFReader(fis);
// 調用DBFReader對實例方法得到path文件中欄位的個數
int fieldsCount = reader.getFieldCount();
// 取出欄位信息
for (int i = 0; i < fieldsCount; i++) {
DBFField field = reader.getField(i);
System.out.print(field.getName());
}
Object[] rowValues;
// 一條條取出path文件中記錄 rowValues.length;
while ((rowValues = reader.nextRecord()) != null) {
for (int i = 0; i < rowValues.length; i++) {
System.out.println(rowValues[i]);
}
}
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
fis.close();
} catch (Exception e) {
}
}
}
public static void main(String[] args) {
readDBF.readDBF("Y:/dbf/01-04-2013/sjshq.DBF");
}
}