Форум программистов, компьютерный форум, киберфорум
LINQ
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
2 / 1 / 3
Регистрация: 08.11.2016
Сообщений: 24

Оставить только уникальные значение в таблице по одному столбцу без учета регистра, символов и пробелов на конце

14.08.2019, 09:19. Показов 2259. Ответов 4

Студворк — интернет-сервис помощи студентам
Добрый день,
Зашел в тупик. За любые подсказки буду благодарен. Надо оставить по столбцу все уникальные значения без учета регистра, символов и пробелов на конце.

Смог написать без учета регистра, но вот символы и пробелы не могу придумать как.
Без учета регистра рабочий:
Кликните здесь для просмотра всего текста
firstDT.AsEnumerable().GroupBy(Function( row) row("D".ToExcelColIndex).ToString, StringComparer.OrdinalIgnoreCase).Select (Function(g) g.First).AsEnumerable().Where(Function(r ow) String.IsNullOrWhiteSpace(row.Item(0).To String) <> true).CopyToDataTable


Попытка усовершенствовать:
Кликните здесь для просмотра всего текста
firstDT.AsEnumerable().GroupBy(Of DataRow, DataRow)(Function(row) row, Comparer(Of DataRow).Create(Function(x1 As DataRow, x2 As Datarow) String.Compare(x1(0).ToString, x2(0).ToString, CultureInfo.CurrentUICulture, CompareOptions.IgnoreSymbols Or CompareOptions.IgnoreCase))).Select(Func tion(g) g.First).AsEnumerable().Where(Function(r ow) _
String.IsNullOrWhiteSpace(row.Item(0).To String) <> True).CopyToDataTable

Но не получатся, ругается на CompareOptions
Буду благодарен за любую подсказку!
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.08.2019, 09:19
Ответы с готовыми решениями:

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

В тексте, содержащем между словами от 1 до 3 пробелов, оставить только по одному
В тексте, содержащем между словами от 1 до 3 пробелов, оставить только по одному.

Строковые переменные: в тексте, содержащем между словами до трех пробелов, оставить только по одному
В тексте, содержащем между словами от 1 до 3 пробелов, оставить только по одному. Помогите

4
2810 / 1679 / 885
Регистрация: 14.04.2015
Сообщений: 5,723
14.08.2019, 09:36
BluSterben, дай тестовые данные хоть, которые на вход подаешь
0
2 / 1 / 3
Регистрация: 08.11.2016
Сообщений: 24
14.08.2019, 09:44  [ТС]
Таблица с несколькими столбцами: мы работаем по столбцу A и D.
В столбце A мы просто смотрим что там не пусто, и тогда отправляем на выход, код за это отвечающий: AsEnumerable().Where(Function(row) String.IsNullOrWhiteSpace(row.Item(0).To String) <> true).CopyToDataTable


Но мне интересен именно столбце D, в нем данные такие(<> - это просто показываю начало и конец значения, так как могут быть пробелы в конце строки):
<АО "Завод" >
<АО ЗаВод>
<ООО "Банк" >
<ООО "Магазин">
<АО "Магазин">
Надо получить на выходе первое не повторяющийся значение:
<АО "Завод">
<ООО "Банк" >
<ООО "Магазин">
<АО "Магазин">
0
2810 / 1679 / 885
Регистрация: 14.04.2015
Сообщений: 5,723
14.08.2019, 10:49
Лучший ответ Сообщение было отмечено BluSterben как решение

Решение

BluSterben, я бы сделал так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
using System;
using System.Collections.Generic;
using System.Linq;
 
namespace ConsoleApp101
{
    class Program
    {
        static void Main(string[] args)
        {
            List<string> Organization = new List<string>
            {
                "<АО \"Завод\">",
                "<АО ЗаВод>",
                "<ООО \"Банк\" >",
                "<ООО \"Магазин\">",
                "<АО \"Магазин\">"
            };
 
            List<UniqOrganization> ListUniqOrganization = new List<UniqOrganization>();
 
            foreach (var Row in Organization)
            {
                UniqOrganization AddDataForDistinct = new UniqOrganization
                {
                    KeyOrganization = new string(Row.Where(c => Char.IsLetterOrDigit(c)).ToArray()).ToLower(),
                    ValueOrganization  = Row
                };
 
                ListUniqOrganization.Add(AddDataForDistinct);                
            }
 
            var DistinctOrganization = ListUniqOrganization.GroupBy(g => g.KeyOrganization).Select(s => s.OrderBy(p => p.ValueOrganization).FirstOrDefault()).ToList();
 
            foreach (var Row in DistinctOrganization)
            {               
               Console.WriteLine(Row.ValueOrganization);
            }
        }
    }   
    public struct UniqOrganization
    {
        public string KeyOrganization { get; set; }
 
        public string ValueOrganization { get; set; }
    }
}
1
2 / 1 / 3
Регистрация: 08.11.2016
Сообщений: 24
14.08.2019, 13:08  [ТС]
AndreyVorobey, хорошее решение. Навело меня на одну очень хорошую мысль. Спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.08.2019, 13:08
Помогаю со студенческими работами здесь

Поиск и выделение символов в RichTextBox без учета регистра
Здравствуйте, подскажите пожалуйста как выполнить поиск в тексте в (RichTextBox)так чтобы если юзер ввел для поиска &quot;п&quot;, то он...

Подсчет символов в строке без учета пунктуации и пробелов
вобщем такая история. я ввожу текст в richTextBox1, удаляю оттуда все пробелы, запятые, точки и тд. и дальше мне нужно посчитать количество...

Получить число символов строки без учета пробелов
Выдает число символов строки без учета пробелов - макрос. Помогите, пожалуйста

Получить число символов строки без учета пробелов
13. Выдает число символов строки без учета пробелов. Добавлено через 7 минут В помощь: 1. Открыть MS Excel. 2. Сохранить книгу...

Ввести 2 строки с клавиатуры. Определить, одинаковые ли строки без учета регистра, пробелов и знаков препинания
Ввести 2 строки с клавиатуры. Определить одинаковые ли строки без учета регистра, пробелов и знаков препинания. в с++


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru