Member 12705538 Ответов: 3

Объект DataTable фильтр, используя данные в приложение.config и приложение c#


Сценарий: у меня есть datatable, который заполняет данные в datagrid динамически/во время выполнения, как показано ниже:

dt.Rows.Add(value1, value2, value3, value4, value5, value6, value6, value7, value8);


Теперь у меня есть данные в файле app. config, которые я извлекаю, как показано ниже:

// app.config file contains string with comma separated and I am splitting it in code

string num1 = ConfigurationManager.AppSettings["crNum"];
string[] values = num1 .Split(',');

foreach (string crNum in values)
{
    // I need code here to delete the entire rows where value1 == crNum 
    // in my above data table dt and also when I reopen/refresh 
    // my c# application I should not see the row deleted before.
}


Наконец-то я вставить таблицу в таблицу

myCRGrid.DataSource = dt;


Я новичок в C#, прошу прощения за такой странный вопрос.

Пожалуйста помочь

Спасибо!

Что я уже пробовал:

я попытался удалить, но мне это не удалось, а также запутаться в написании кода внутри цикла foreach

FranzBe

app .config не должен содержать данные приложения, для этого вы должны использовать какой-то файл.csv; app.config должен содержать только информацию, связанную с "конфигурацией". Это поможет понять ваш вопрос, если вы опубликуете некоторые примеры данных

3 Ответов

Рейтинг:
0

FranzBe

asumming, что "demodata. csv" выглядит следующим образом

42,1,2,3,4,5,6,7
43,7,6,5,4,3,2,1
42,2,3,4,5,6,7,8
44,9,8,7,6,5,4,3



я бы предложил что-то вроде этого

void Main()
{
	var records = ProcessMyData(@"c:\temp\demodata.csv");
	
	var filteredRecords =
	       records.Where(x => x.Value1 != "42");
		   
	// now you have the records of the file you want
	// you may assign that without use of a datatable to your grid
	
}

// Define other methods and classes here
class MyData
{
	public string Value1 { get; set; }
	public string Value2 { get; set; }
	public string Value3 { get; set; }

	internal static MyData ParseFromCsv(string line)
	{
		var c = line.Split(',');
		return new MyData
		{
			Value1 = c[0],
			Value2 = c[1],
			Value3 = c[2]
			//....
		};
	}
}


private static List<MyData> ProcessMyData(string path)
{
	return File.ReadAllLines(path)
		.Select(MyData.ParseFromCsv)
		.ToList();
}


Рейтинг:
0

Karthik_Mahalingam

попробовать это

foreach (DataRow row in dt.Rows)
       {
           if (values.Contains(row["Value1"].ToString()))
               row.Delete();
       }
       dt.AcceptChanges();


Рейтинг:
0

Halit Yurttaş

Хорошо, теперь попробуйте ниже код. Its remove your value contain rows by found from select method. Выберите метод return ICollection<datarow>

string num1 = ConfigurationManager.AppSettings["crNum"];
string[] values = num1 .Split(',');
 
foreach (string crNum in values)
{
    foreach (var nrow in dt.Select("Value1 = " + crNum))
    {
        dt.Rows.Remove(nrow);
    }
}