C# 打开外部dbf表格,转为DataTable

先去下载并安装VFPOLEDBSetup.msi,网上很多。

OpenFileDialog openDialog = new OpenFileDialog();
openDialog.Filter = "Dbf(*.dbf)|*.dbf|ALL Files(*.*)|*.*";
openDialog.Title = "选择表数据";

if(DialogResult.OK == openDialog.ShowDialog())
  {
     string strDbfPath = openDialog.FileName;
     FileInfo fi = new FileInfo(strDbfPath);
     string mulu = fi.DirectoryName;
     string filename = fi.Name;
     OleDbConnection conn = new OleDbConnection();    
     string connStr = "Provider = VFPOLEDB.1; Data Source = "+ mulu +"; Collating Sequence = MACHINE";
     conn.ConnectionString = connStr;
     conn.Open();

     string sql = "select * from" + strDbfPath;
     OleDbDataAdapter da = new OleDbDataAdapter(sql, conn);
     DataTable dt = new DataTable();
     da.Fill(dt);

  }

(引用处要添加using System.Data.OleDb )

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
用oledb读取dbf文件报错--“外部表不是预期的格式” 我的代码如下 string ole_connstring=String.Empty; ole_connstring = @"Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=dBASE IV;Data Source="+FilePath; OleDbConnection ole_conn = new OleDbConnection(ole_connstring); ole_conn.Open(); string insertsql="Insert into ["+tableName+"] (.......; OleDbCommand da=new OleDbCommand(insertsql,ole_conn); da.ExecuteNonQuery(); DBF版本问题,用VFP9的OLEDB即可 方法一: 进入VFP USE TT COPY TO NEWTT TYPE FOX2X 此方法是把表的文件版本转为新的VFP文件版本解决版本问题。 方法二: 升级JET 引擎到SP8,安装MDAC 2.8,到MS的网站去找 1、VFP9的驱动是最新的,各种版本的DBF均可读出; 2、你的连接字串是用JET的引擎,故要升级JET及MDAC; 3、所需文件在MS的网站均有下载。 方法三: 安装vfpoledb.exe(VFP9的OLEDB),在项目中引用Microsoft OLE DB Provider for FoxPro 7.0 Type Library 1.0,然后使用如下代码: OleDbConnection con = new OleDbConnection("Provider=VFPOLEDB.1;Data Source=D:\\2006工程\\南京建设质量监督站\\资料;Collating Sequence=MACHINE"); con.Open(); DataTable dtQY=new DataTable(); OleDbDataAdapter adapt=new OleDbDataAdapter(); adapt.MissingSchemaAction=MissingSchemaAction.AddWithKey; adapt.SelectCommand = new OleDbCommand("select * from 200512.DBF",con); adapt.Fill(dtQY); adapt.Dispose(); DataView dvQY = dtQY.DefaultView; dtQY.Dispose(); con.Close();
你可以使用C#中的一些库来导出DBF文件到Excel。一个常用的库是NPOI,它可以帮助你进行Excel文件的读写操作。以下是一个简单的示例代码,演示如何将DBF文件导出到Excel: ```csharp using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.Data.OleDb; class Program { static void Main(string[] args) { string dbfFilePath = "path_to_your_dbf_file.dbf"; string excelFilePath = "path_to_save_excel_file.xls"; // 创建Excel工作簿 var workbook = new HSSFWorkbook(); var sheet = workbook.CreateSheet("Sheet1"); // 读取DBF文件数据 using (var connection = new OleDbConnection($"Provider=Microsoft.Jet.OLEDB.4.0;Data Source={System.IO.Path.GetDirectoryName(dbfFilePath)};Extended Properties=dBASE IV;")) { connection.Open(); var command = new OleDbCommand($"SELECT * FROM {System.IO.Path.GetFileName(dbfFilePath)}", connection); var reader = command.ExecuteReader(); // 写入Excel文件 int rowIndex = 0; while (reader.Read()) { var row = sheet.CreateRow(rowIndex); for (int i = 0; i < reader.FieldCount; i++) { var cell = row.CreateCell(i); cell.SetCellValue(reader.GetValue(i)?.ToString()); } rowIndex++; } } // 保存Excel文件 using (var fileStream = new System.IO.FileStream(excelFilePath, System.IO.FileMode.Create)) { workbook.Write(fileStream); } Console.WriteLine("DBF文件已成功导出到Excel文件。"); } } ``` 请注意,这个示例假设你已经安装了 NPOI 库,并且你需要将其添加到你的项目引用中。您还需要根据实际情况修改 `dbfFilePath` 和 `excelFilePath` 变量,将其设置为正确的文件路径。 希望这可以帮助到你!如有任何疑问,请随时询问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值