我正在编写一个小应用程序来对我拥有的 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 中添加另一个逗号,那是因为我将街道地址字段与邮政编码字段组合在一起 - 我希望这不会搞砸任何事情。
我的代码有点乱,因为我只是想编辑一个文件来做一个小的修复,很抱歉。
最佳答案
编辑单个列值的最简单方法是使用 DataRow.Item
索引器属性:
readIn.Rows[i][numColumnToCopyTo] = (object)towrite;
这没有很好的记录,但是 DataRow.ItemArray
的 get
访问器返回基础数据的副本。这是实现,由 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;
关于c# - 更新数据表中的单元格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2448510/