[英]DataTable/DataGridView Row Number Display
我想在我的DataGridView
第一列中显示,但没有找到一个好的解决方案。 我尝试将新列添加到DGV,但崩溃了。
List<string[]> rows = File.ReadAllLines(Open_CSV.FileName,
Encoding.ASCII).Select(x => x.Split(';')).ToList();
DataTable dt = new DataTable();
foreach (string s in rows[0])
{
dt.Columns.Add(s);
}
rows.RemoveAt(0);
rows.ForEach(x =>
{
dt.Rows.Add(x);
});
DGV_DATA.DataSource = dt;
您是否有一些解决方案,将最佳位置添加到DataTable
或DataGridView
?
不知道它是否非常有效,但这可以解决问题
List<string[]> rows = File.ReadAllLines(......)
.Select((x,i) =>
string.Join(";", (i+1).ToString(), x)
.Split(';')).ToList();
您可以使用Select的版本,该版本使用序列中当前项目的索引器,并将该索引添加到将被拆分的字符串中。
我的担心与以下事实有关:通过这种方式您可以构建其他字符串,但是无需在以下代码中进行任何更改。
如您所料,在使用DataSource
,手动添加数据可能会导致问题。 只要行号不属于数据,向数据DataSource
添加行号显然不是一个好主意。 在这种情况下,一个想法是在行标题显示数字,如所描述这里 。
在您自己的情况下,您自己构建DataSource时,您可能会考虑离开使用DataSource-Property的路径,然后直接开始添加行。 DataGridView
的Rows
-Property可用于手动添加行。 您只需要构建类似于DataGridViewRow
-objects的列表,就可以将其传递给AddRange
-method。 您可以向这些DataGridViewRows
添加其他列。 并确保还将该附加列也添加到DataGridView
的Columns
-Collection中。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.