|
0 / 0 / 0
Регистрация: 16.05.2009
Сообщений: 142
|
|
Поиск дублирующих строк в документе16.02.2011, 15:18. Показов 28418. Ответов 8
Метки нет (Все метки)
В общем необходимо найти дубли в многострочном документе (дублем считается строка совпадающая с более ранней строкой по ряду параметров). Первоначально делал как отдельную процедуру - не работало. В итоге внес проверку в тело основной процедуры, в итоге заработало, но некорректно - за дубль программа принимает только предпоследнюю дублирующую строку в документе вне зависимости от того сколько их имеется. Поясню: например у нас 10 строк, строки 1 и 3 имеют дубликаты с номерами 2, 6 и 8,9 соответственно. Так вот, в результате проверки как дубль будет выведена только строка 8 и все!!
Код ( (Unknown Language)): СписокДублей = СоздатьОбъект("СписокЗначений"); ВыбратьСтроки(); НомерПоПорядку=1; Пока ПолучитьСтроку() = 1 Цикл Если СписокДублей.НайтиЗначение (НомерПоПорядку)= 0 Тогда Для СчетСтр=1 по КоличествоСтрок() Цикл ПолучитьСтрокуПоНомеру(СчетСтр); Если (СчетСтр<>НомерПоПорядку) Тогда Если (Фамилия=ФамилияПациента) и (Имя=ИмяПациента) и (Отчество=ВРЕГ(СокрЛП(ОтчествоПациента) и ДатаРожд=ДатаРожденияПациента) и (Профиль =КодПрофиля) Тогда // СписокДублей.ДобавитьЗначение(СчетСтр); КонецЕсли; КонецЕсли; КонецЦикла; КонецЕсли; ПолучитьСтрокуПоНомеру(НомерПоПорядку); Если СписокДублей.НайтиЗначение (НомерПоПорядку)= 1 Тогда Дубли="V"; КонецЕсли; Если (Дубли="V") Тогда ТЗ.НоваяСтрока(); ТЗ.Фамилия = Фамилия; ТЗ.Имя = Имя; ТЗ.Отчество = Отчество; ТЗ.ДатаРождения = ДатаРожд; ТЗ.Дубликат = Дубли; КонецЕсли; НомерПоПорядку=НомерПоПорядку+1; КонецЦикла; Таб=СоздатьОбъект("Таблица"); Таб.ИсходнаяТаблица("Ошибки"); Таб.ВывестиСекцию("Заголовок"); ТЗ.ВыбратьСтроки(); // открываем выборку строк из д. таблицы Пока ТЗ.ПолучитьСтроку()=1 Цикл Фамилия=ТЗ.Фамилия; Имя=ТЗ.Имя; Отчество=ТЗ.Отчество; ДатаРождения = ТЗ.ДатаРождения; Повтор = ТЗ.Дубликат; Таб.ВывестиСекцию("Ошибка"); КонецЦикла; Таб.ТолькоПросмотр(1); Таб.ПараметрыСтраницы(1,100,1); Таб.Показать("Ошибки",""); Список параметров для сравнения и количество полей в Таблице Значений сокращены для улучшения читаемости; за вывод результата отвечает переменная Повтор печатной формы "Ошибки". Вроде бы простецкая задачка, а все никак не могу наладить корректный вывод результатов ;)
0
|
|
| 16.02.2011, 15:18 | |
|
Ответы с готовыми решениями:
8
Упорядочивание строк в документе 7.7 Количество строк в документе Очистка строк в табличном документе |
|
0 / 0 / 0
Регистрация: 01.01.2010
Сообщений: 226
|
|
| 16.02.2011, 15:26 | |
|
А какое действие должно быть в результате нахождения дубля?
И много строчек может быть в т.ч. ?
0
|
|
|
0 / 0 / 0
Регистрация: 16.05.2009
Сообщений: 142
|
||
| 16.02.2011, 15:35 | ||
Предварительно создаю список значений. Далее начинаю перебирать строки документа. Если номер текущей строки отсутствует в СЗ, то начинаем проверять все строки документа с первой по последнюю. При совпадении указанных параметров заносим номер строки (из второго цикла) в СЗ (естественно строку с самой собой не сравниваем). После окончания проверки позиционируемся опять на нужную строку (НомерПоПорядку) и проверяем наличие этого номера в СЗ, если есть - то переменную Дубли приравниваем к "V". Далее при наличии ошибки заносим данные по человеку в ТЗ, по окончании полного цикла проверки перебираем ее строки и выводим на экран. Строчек может быть и 1, и 1000, я пока проверяю на маленьких примерах (копирую 2-3 строки по 2-3 раза и запускаю проверку). Код очень корявый, но он работает, правда совсем не так как надо(
0
|
||
|
0 / 0 / 0
Регистрация: 01.01.2010
Сообщений: 226
|
|
| 16.02.2011, 15:35 | |
|
Вообщем так. Лень разбираться в коде, преложу такой вариант.
- выгружаеш в тз; - задаеш переменную дубль=0; - Выборка строк; - пока получаеш строку перебираеш тз, если находиш дубль по параметрам - ставиш переменную+1; - В конце проверка - Если дубль>1 тогда действие; - обнуление переменной; Вообщем как-то так
0
|
|
|
0 / 0 / 0
Регистрация: 16.05.2009
Сообщений: 142
|
||
| 16.02.2011, 15:55 | ||
Завтра с утра проверю все, а то осталось 15 минут и процессор уже совсем не варит..
0
|
||
|
0 / 0 / 0
Регистрация: 01.01.2010
Сообщений: 226
|
||
| 16.02.2011, 16:02 | ||
Сам уже домой иду, устал седня по самое...
0
|
||
|
1 / 1 / 0
Регистрация: 15.11.2009
Сообщений: 947
|
||
| 16.02.2011, 23:05 | ||
- выгружаеш в тз; - добавить колонку Дубль - пройти по строкам и проставить 1 - Свернуть. Полей для сравнения вижу много. Получается компактненько.
0
|
||
|
0 / 0 / 0
Регистрация: 22.04.2010
Сообщений: 38
|
|
| 17.02.2011, 14:34 | |
|
выгрузить таб часть в 2 таблицы значений, одну свернуть по параметрам и сравнить количество строк отличается, есть дубли строк
0
|
|
|
0 / 0 / 0
Регистрация: 16.05.2009
Сообщений: 142
|
|
| 17.02.2011, 15:15 | |
|
Уфф.. наконец-то, я это сделал. Сделал с использованием второй ТЗ и СЗ, но дело было совсем не в этом. Виновата была строчка
Код ( (Unknown Language)): Если СписокДублей.НайтиЗначение (НомерПоПорядку)= 1 Тогда Помня, что если значение не найдено, то возвращается 0, я автоматически решил, что при обнаружении возвращаться должно 1, не удосужившись проверить синтаксис Само собой что при выводе он видел только первую дублирующую строку Хула мне, стало быть и позор Потратил кучу времени на элементарную процедуру, но еще раз понял простую мысль: Если алгоритм правильный, а что-то не получается - надо обязательно проверить синтаксис. Всем еще раз спасибо
0
|
|
| 17.02.2011, 15:15 | |
|
Помогаю со студенческими работами здесь
9
Нарушение порядка строк в документе 7.7 Контекстный Поиск В Документе Порядок строк в документе "на основании"
Удаление дублирующих строк в ListView Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|