C#下dBase file的构建

对shape file的属性进行了计算,为了数据格式的统一,欲将结果存为dBase file。
折腾了两天,终于搞定了。(代价是目前双眼发之中 blank.gif [:|] blank.gif

(一)空数据文件的生成
string pnlfilename = shapeFileName.Substring(0,shapeFileName.Length-4) + "_pnl
.dbf";
if(File.Exists(pnlfilename) == true)
File.Delete(pnlfilename);
IFeatureWorkspace pFWS;
IWorkspaceFactory pWorkspaceFactory = new ShapefileWorkspaceFactoryClass();
string name = null;
FileInfo file = new FileInfo(pnlfilename);
name = file.Name;//filename
string path = file.Directory.FullName + "\\"; //file path
pFWS = pWorkspaceFactory.OpenFromFile(path,0) as IFeatureWorkspace;

IFields fields = new FieldsClass();
IFieldsEdit fieldsEdit = fields as IFieldsEdit;
IField field = new FieldClass();
IFieldEdit fieldEdit = field as IFieldEdit;
fieldEdit.Length_2 = 10;
fieldEdit.Name_2 = "poly";
fieldEdit.Type_2 = esriFieldType.esriFieldTypeInteger;
fieldsEdit.AddField(field);
field = new FieldClass();
fieldEdit = field as IFieldEdit;
fieldEdit.Length_2 = 150;
fieldEdit.Name_2 = "pnl";
fieldEdit.Type_2 = esriFieldType.esriFieldTypeString;
fieldsEdit.AddField(field);

ITable table = pFWS.CreateTable(name,fields,(ESRI.ArcGIS.esriSystem.UID)null,(
ESRI.ArcGIS.esriSystem.UID)null,"");

本来打算用ODBC/OLDB/ADO来做的,动起来才发现一个要命的问题,因为上述方法都是基于
SQL的,所以必须有对应的数据库(文件)存在,也就是说上述方法较适用于dBase文件的
修改,而新建则难以实现。(对于Access文件,可以通过称作ADOX的COM来实现新建文件功
能)

本来以为剩下的方法只能按照dBase格式来代码创建了,那在现有条件下几乎不可能。

google不到,无奈之下侥幸的翻了一下vs的help,居然找到了:在Arc Engine的帮助里有
建立dBase文件的vb示例!想想也是,全是因为shape文件出来的早,现在别的地方也难有
人用这旧dBase格式存数据了。于是用C#语言小修改了一下~

(二)数据填充
for(int i=0;i<pnlTable.Rows.Count;i++)
{
    //IRow row = table.CreateRow();
//row.set_Value(table.FindField("poly"),pnlTable.Rows[i].ItemArray[pnlTable.C
olumns["poly"].Ordinal]);
//row.set_Value(table.FindField("pnl"),pnlTable.Rows[i].ItemArray[pnlTable.Co
lumns["pnl"].Ordinal]);
//row.Store();

IRowBuffer row = table.CreateRowBuffer();
row.set_Value(table.FindField("poly"),pnlTable.Rows[i].ItemArray[pnlTable.Col
umns["poly"].Ordinal]);
row.set_Value(table.FindField("pnl"),pnlTable.Rows[i].ItemArray[pnlTable.Colu
mns["pnl"].Ordinal]);
table.Insert(true).InsertRow(row);
}

注释掉的是先前使用的方法,采用row对象来存储中间数据;而后采用的方法是用rowbuff
er来存储。前者操作均是基于数据库(文件)的,而后者则先在内存中构建,再插入到数
据库(文件)中。试验表明,相比较而言,后者可以节省1/2到2/3的时间消耗。

最后要说明的一点,在文件建立之前,不推荐使用ESRI提供的Table对象来存储数据,因为
其可能是基于数据库(文件)操作的,而一般ADO.net则较多采用了缓存技术。时间消耗上
面的差距是不能比拟的。

转载于:https://www.cnblogs.com/columbus2/archive/2007/08/02/840333.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用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` 变量,将其设置为正确的文件路径。 希望这可以帮助到你!如有任何疑问,请随时询问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值