Я новичок в ListView
и столкнулся с небольшой проблемой:
У меня есть ListView
in WinForm
, который я заполняю строку за строкой со многими столбцами (около 15), позже у меня есть возможность сохранить ListView
в CSV
. я хочу, чтобы пользователь мог удалить ненужные столбцы из ListView
.
Моя функция для создания столбцов сначала
private void checkAddListBoxColumns(DomainLayer.ScriptLogic.session sessionToAdd)
{
if (IsResultLogListViewFirstRun)
{
IsResultLogListViewFirstRun = false;
this.Invoke((MethodInvoker)delegate
{
ResultsLogTab_ListView.Columns.Clear();
});
foreach (var item in sessionToAdd.comments.Keys)
{
this.Invoke((MethodInvoker)delegate
{
ResultsLogTab_ListView.Columns.Add(item);
});
}
McsTableRow mcsTR = new McsTableRow();
Type t = mcsTR.GetType();
foreach (/*PropertyInfo*/FieldInfo info in t.GetFields())
{
this.Invoke((MethodInvoker)delegate
{
ResultsLogTab_ListView.Columns.Add(info.Name+" 1");
});
}
foreach (FieldInfo info in t.GetFields())
{
this.Invoke((MethodInvoker)delegate
{
ResultsLogTab_ListView.Columns.Add(info.Name+" 2");
});
}
this.Invoke((MethodInvoker)delegate
{
ResultsLogTab_ListView.Columns.Add("Effective PHY Rate");
});
//...more of the same
}
else
{
//?
}
}
позже я добавляю строку типа
private OnSessionToAdd()
{
foreach (string key in sessionToAdd.comments.Keys)
{
item.SubItems.Add(sessionToAdd.comments[key]);
}
Type t = sessionToAdd.CurrentMCSCheck.firstMcsRow.GetType();
foreach (FieldInfo info in t.GetFields())
{
string x = info.GetValue(sessionToAdd.CurrentMCSCheck.firstMcsRow) as string;
item.SubItems.Add(x);
}
t = sessionToAdd.CurrentMCSCheck.secondMcsRow.GetType();
foreach (FieldInfo info in t.GetFields())
{
string x = info.GetValue(sessionToAdd.CurrentMCSCheck.secondMcsRow) as string;
item.SubItems.Add(x);
}
item.SubItems.Add(sessionToAdd.CurrentMCSCheck.EffectivePHYRate);
this.Invoke((MethodInvoker)delegate
{
ResultsLogTab_ListView.Items.Add(item);
});
}
Мне нужен способ получить все имена столбцов, а затем удалить столбцы по имени или какой-то IndexOf (имя)
Пожалуйста, укажите мне правильное направление
ИЗМЕНИТЬ
просто для ясности я не скрываю столбцы (ширина настроек = 0) я хочу удалить их, чтобы помочь вам понять мою точку зрения, я добавил, как я сохраняю ListView
, как я сохраняю в CSV:
public StringBuilder ListViewToCSV(ListView listView, string filePath, bool includeHidden)
{
//make header string
StringBuilder result = new StringBuilder();
WriteCSVRow(result, listView.Columns.Count, i => includeHidden || listView.Columns[i].Width > 0, i => listView.Columns[i].Text);
//export data rows
foreach (ListViewItem listItem in listView.Items)
WriteCSVRow(result, listView.Columns.Count, i => includeHidden || listView.Columns[i].Width > 0, i => listItem.SubItems[i].Text);
return result;
}
private static void WriteCSVRow(StringBuilder result, int itemsCount, Func<int, bool> isColumnNeeded, Func<int, string> columnValue)
{
bool isFirstTime = true;
for (int i = 0; i < itemsCount; i++)
{
if (!isColumnNeeded(i))
continue;
if (!isFirstTime)
result.Append(",");
isFirstTime = false;
result.Append(String.Format("\"{0}\"", columnValue(i)));
}
result.AppendLine();
}
чем просто сохранить StringBuilder
ListView
или имена из CSV? 17.09.2014ColumnHeader
имеет свойствоName
. Еще раз, это здесь, на MSDN 17.09.2014