1

我正在编写一个小应用程序来对我拥有的 CSV 文件中的某些单元格进行一些处理。我已经想出了如何使用我在网上找到的库来读取和写入 CSV 文件,但是我遇到了麻烦:该库将 CSV 文件解析为 DataTable,但是,当我尝试更改表格的一个单元格时,它是'不保存表中的更改!

下面是有问题的代码。我已将流程分成多个变量,并重命名了一些内容,以便更轻松地针对这个问题进行调试。

代码

循环内部:

string debug1 = readIn.Rows[i].ItemArray[numColumnToCopyTo].ToString();
string debug2 = readIn.Rows[i].ItemArray[numColumnToCopyTo].ToString().Trim();
string debug3 = readIn.Rows[i].ItemArray[numColumnToCopyFrom].ToString().Trim();
string towrite = debug2 + ", " + debug3;
readIn.Rows[i].ItemArray[numColumnToCopyTo] = (object)towrite;

循环后:

readIn.AcceptChanges();

当我调试我的代码时,我看到towrite正在正确形成并且一切正常,除了该行没有更新:为什么它不工作?我有一种感觉,我在这里犯了一个简单的错误:我上次使用 DataTables 时(很久以前),我遇到了类似的问题。

如果您想知道我为什么要在towrite中添加另一个逗号,那是因为我将街道地址字段与邮政编码字段结合在一起 - 我希望这不会搞砸任何事情。

我的代码有点乱,因为我只是想编辑一个文件来做一个小修复,很抱歉。

4

2 回答 2

4

编辑单个列值的最简单方法是使用DataRow.Itemindexer 属性:

readIn.Rows[i][numColumnToCopyTo] = (object)towrite;

这没有详细记录,但DataRow.ItemArray'sget访问器返回底层数据的副本。这是由Reflector提供的实现:

public object[] get_ItemArray() {
    int defaultRecord = this.GetDefaultRecord();
    object[] objArray = new object[this._columns.Count];
    for (int i = 0; i < objArray.Length; i++) {
        DataColumn column = this._columns[i];
        objArray[i] = column[defaultRecord];
    }
    return objArray;
}

编辑列值有一种尴尬的替代方法:获取一行ItemArray,修改这些值,然后修改行以使用更新后的数组:

object[] values = readIn.Rows[i].ItemArray;
values[numColumnToCopyTo] = (object)towrite;
readIn.Rows.ItemArray = values;
于 2010-03-15T16:38:00.567 回答
0

使用SetField<>方法:

    string debug1 = readIn.Rows[i].ItemArray[numColumnToCopyTo].ToString();
    string debug2 = readIn.Rows[i].ItemArray[numColumnToCopyTo].ToString().Trim();
    string debug3 = readIn.Rows[i].ItemArray[numColumnToCopyFrom].ToString().Trim();
    string towrite = debug2 + ", " + debug3;
    readIn.Rows[i].SetField<string>(numColumnToCopyTo,towrite); 

    readIn.AcceptChanges();
于 2013-03-11T18:19:16.350 回答