Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
12 / 12 / 1
Регистрация: 18.06.2011
Сообщений: 435

Как сравнить два csv файла по определенной колонке?

19.08.2016, 21:22. Показов 2413. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть два файла

C#
1
2
var csv1 = File.ReadAllLines("1.csv");
var csv2 = File.ReadAllLines("2.csv");
Я сперва использовал стандартное сравнение с помощью следующего кода

C#
1
var rezCSV = buffList1.Except(csv2).Union(csv2.Except(csv1)).ToList();
Все хорошо, теперь стоит вопрос в том как использовать вышеприведенный код по определенным столбцам в csv-файле. Как сделать чтобы сравнение шло по второй ячейке csv-файла? Разделитель между колонками ;
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.08.2016, 21:22
Ответы с готовыми решениями:

Как проверить значение в определенной строке и колонке из БД?
нужно проверить в определенном поле одну опред. строку ) скажем поле 8 строка 5 и если там есть какое то значение нужно вывести...

Как сравнить два файла на компьютере и на сервере?
Привет всем! Как можно рассчитать hex/md5 код файла на компьютере и на сервере (http://site.com//....//file.qwerty)?

Как обратиться к определенной колонке ТЗ и к определенной строке из этой колонки?
Как обратиться к определенной колонке ТЗ и к определенной строке из этой колонки? Добавлено через 44 секунды Колонку выбрать по...

3
186 / 184 / 97
Регистрация: 30.04.2016
Сообщений: 478
22.08.2016, 11:34
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
var csv1 = File.ReadAllLines("");
            var matrix1 = new List<List<string>>();
            foreach (var s in csv1)
            {
                var cells = s.Split(new[] {';'}, StringSplitOptions.RemoveEmptyEntries).ToList();
                matrix1.Add(cells);
            }
 
            var csv2 = File.ReadAllLines("");
            var matrix2 = new List<List<string>>();
            foreach (var s in csv2)
            {
                var cells = s.Split(new[] { ';' }, StringSplitOptions.RemoveEmptyEntries).ToList();
                matrix2.Add(cells);
            }
 
            var columnNumber = 2;
 
            var columnsAreEquals = matrix1.Select(r => r[columnNumber]).SequenceEqual(matrix2.Select(r=>r[columnNumber]));
Не знаю на сколько большой у Вас csv. Этот код можно еще оптимизировать, например, сплитить только до нужной колонки.
0
12 / 12 / 1
Регистрация: 18.06.2011
Сообщений: 435
22.08.2016, 13:17  [ТС]
Спасибо за решение, однако в вашем примере сравнение по одной колонке. А мне нужно по двум разным колонкам
0
186 / 184 / 97
Регистрация: 30.04.2016
Сообщений: 478
22.08.2016, 13:26
Цитата Сообщение от Radzhab Посмотреть сообщение
по двум разным колонкам
А в чем проблема?

C#
1
2
3
var firstColumnIndex = 2;
var secondColumnIndex = 3;
var columnsAreEquals = matrix1.Select(r => r[firstColumnIndex]).SequenceEqual(matrix2.Select(r=>r[secondColumnIndex]));
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.08.2016, 13:26
Помогаю со студенческими работами здесь

Как сравнить два файла?
Хочу сравнить два файла быстро, но не по байтно. Проблема: Есть сервер и клиент. Нужно сравнить файл лежащий один на сервере. Другой на...

Как сравнить два текстовых файла?
Необходимо сравнить два текстовых файла с помощью очереди. Может, у кого есть такая программа в полноэкранном виде?

Как сравнить два текстовых файла?
Скажите пожалуйста как сравнить два тхт являются ли их содержания одинаковыми? И если нет то показать где именно ошибка на 3 м тхт файле. ...

Как в таблице обратиться к определенной колонке
Есть табл fxml. Колонки: Firstname, Lastname, Phone, Email Я хочу сделать слушатель на колонку Email Что бы при нажатии на любой...

Как и чем сравнить два аудио файла?
Есть несколько файлов записи речи, в принципе они все должны быть одинаковые но есть маленькие различия. Нужно отловить эти различия может...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru