#c_sharp #инспекция_кода
Проблема в том что выходит слишком много foreach, как всё это можно сократить? private static string pcCPU; private static string pcGPU; private static string pcLocalIP; private static string pcExternalIP; private static string pcAntivirus; string savePath = @"C:\Sys.txt"; using (FileStream file = new FileStream(savePath, FileMode.Append)) { using (StreamWriter twf = new StreamWriter(file, Encoding.UTF8)) { foreach (ManagementBaseObject avResult in avsearcher.Get()) { pcAntivirus = "& " + (avResult.GetPropertyValue("displayName")).ToString(); pcAntivirus = (pcAntivirus.StartsWith("& ")) ? pcAntivirus.Substring(1) : pcAntivirus; twf.WriteLine(" антивирус: " + pcAntivirus); } foreach (ManagementObject gr in gs.Get()) { foreach (PropertyData pty in gr.Properties) { if (pty.Name == "Description") { pcGPU += pty.Value.ToString(); twf.WriteLine(" Видеоадаптер: " + pcGPU); } } } foreach (ManagementObject gob in sar.Get()) { twf.WriteLine(" Модель компьютера: " + gob["Manufacturer"] + gob["Model"]); } } } P.S: Я вот попробовал так сделать, но тут не получается: 1 - Выводит ошибку Invalid Class 2 - в twf нельзя записать WriteALLtext, можно только Write StringBuilder sb = new StringBuilder(); foreach (ManagementBaseObject avResult in avsearcher.Get()) { Sb.Append(" антивирус: ").Append(pcAntivirus).Append("\n"); } foreach (ManagementObject gr in gs.Get()) { foreach (PropertyData pty in gr.Properties) { if (pty.Name == "Description") { Sb.Append(" Видеоадаптер: ").Append(pcGPU).Append(pty.Value.ToString()).Append("\n");; } } } foreach (ManagementObject gob in sar.Get()) { Sb.Append(" Модель компьютера: ").Append(gob["Manufacturer"]).Append(gob["Model"]).Append("\n");; } twf.Write(sb.ToString()); А вот ошибка: На просторах интернета нашёл интересный код: с использованием List Информация о системе
Ответы
Ответ 1
Например, вы можете отделить получение данных от их вывода. // зачем вам странный трюк с "& "? var avNames = avsearcher.Get() .Cast() .Select(av => (string)av["displayName"]) .ToList(); var graphicCardList = gs.Get() .Cast () .Select(mo => (string)mo["Description"]) .ToList(); var computerInfoList = sar.Get() .Cast () .Select(gob => (string)gob["Manufacturer"] + gob["Model"]) .ToList(); И теперь запись: File.AppendAllLines( savePath, avNames.Select(s => $" Антивирус: {s}"), Encoding.UTF8); File.AppendAllLines( savePath, graphicCardList.Select(s => $" Видеоадаптер: {s}"), Encoding.UTF8); File.AppendAllLines( savePath, computerInfoList.Select(s => $" Модель компьютера: {s}"), Encoding.UTF8); Циклы не нужны вовсе. Ответ 2
сократить вряд ли, а улучшить - разбить на методы отдельные логические участки. Текст собирать в StringBuilder и по завершению запись в файл. Invalid Class - платформа х86 стоит? смените на AnyCPU. Не стоит все брать в using, он нужен для сохранения в файл, когда дойдет до сохранения, там стрим и создать и записать. В sb.ToString() как раз и будет весь текст, он write-ом и запишется
Комментариев нет:
Отправить комментарий