Двойная сортировка массива

26.07.23

Разработка - Универсальные функции

Функция двойной сортировки массива - по типу и значению (тип - по возрастанию, значение - по убыванию).

Скачать файлы

Наименование Файл Версия Размер
Двойная сортировка массива:
.epf 11,77Kb
0
.epf 11,77Kb Скачать

Функция возвращает отсортированный массив

- сначала по строковому представлению типа значения, по возрастанию. Например, если массив содержит 2 значения, типы Число и Булево, то после сортировки на первом месте окажется Булево

- потом по значению в рамках одного типа по убыванию (например, если в массиве есть три числа 3, 55, 7, то после сортировки они встанут рядом, в порядке 55, 7, 3

Исходный массив должен остаться неизменным

Реализовано двумя способами

1) с помощью таблицы и метода Сортировать

2) пузырьком

На форме есть возможность заполнения массива. Для наглядности, в таблицу на форме выводится результат

Учебная задачка, может, кому пригодится.

Протестирована на конфигурации Зарплата и управление персоналом, редакция 3.1 (3.1.27.23).

 

&НаСервере
Функция СортироватьМассивТЗНаСервере(МойМассив)
	
	ТЗ = Новый ТаблицаЗначений;
	ТЗ.Колонки.Добавить("ЗначенияМассива");    // Создание колонки для значений массива
	ТЗ.Колонки.Добавить("ТипЗначенияМассива"); // Создание колонки для типа значений массива

	Для Каждого Стр Из МойМассив Цикл
		СтрокаТЗ = ТЗ.Добавить();         
		СтрокаТЗ.ЗначенияМассива = Стр;
		СтрокаТЗ.ТипЗначенияМассива = Строка(ТипЗнч(Стр));		
	КонецЦикла;

	ТЗ.Сортировать("ТипЗначенияМассива Возр, ЗначенияМассива Убыв");

	СортМассив = ТЗ.ВыгрузитьКолонку("ЗначенияМассива");
	
	Возврат СортМассив;
	
КонецФункции

&НаСервере
Функция СортироватьМассивПузырькомНаСервере(МойМассив)
	
	//загрузим в СортМассив МойМассив
	СортМассив = МойМассив;
	КолВо = МойМассив.Количество()-1;   //количество итераций внутри СортМассив
	
	//сортируем СортМассив по типу
    Для i = 0 По КолВо Цикл
        Для j = 0 ПО КолВо - i - 1 Цикл
            Если Строка(ТипЗнч(СортМассив[j])) > Строка(ТипЗнч(СортМассив[j + 1])) Тогда
                Замена = СортМассив[j];
                СортМассив[j] = СортМассив[j + 1];
                СортМассив[j + 1] = Замена;
            КонецЕсли;            
        КонецЦикла;        
	КонецЦикла;
	
	t = 0;
	Пока t <= КолВо Цикл 
	
		//определим границы однотипных элементов
		tПервый = t;      //первый элемент типа
		tПоследний = t;	  //последний элемент этого же типа
		t = tПервый;
		Тип = Строка(ТипЗнч(СортМассив[t]));
		Пока t <= КолВо Цикл
			Если Строка(ТипЗнч(СортМассив[t])) = Тип Тогда
				tПоследний = t;
			КонецЕсли;	
			t = t + 1;			
		КонецЦикла;                   
		tКолВо = tПоследний - tПервый; //количество итераций на промежутке однотипных элементов
		
		//сортируем элементы СортМассив на промежутке однотипных элементов
	    Для i = 0 По tКолВо Цикл
	        Для j = tПервый По tПоследний - i - 1 Цикл
	            Если СортМассив[j] < СортМассив[j + 1] Тогда
	                Замена = СортМассив[j];
	                СортМассив[j] = СортМассив[j + 1];
	                СортМассив[j + 1] = Замена;
	            КонецЕсли;            
	        КонецЦикла;        
		КонецЦикла;                   
		
		t = tПоследний + 1;
		
	КонецЦикла;                   

	Возврат СортМассив;
	
КонецФункции

 

двойная сортировка массива сортировка методом пузырька сортировка пузырьком

См. также

Печать любых непроведенных документов для УТ, КА, ERP. Настройка печати по пользователям, документам и печатным формам

Пакетная печать Печатные формы Адаптация типовых решений Универсальные функции Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Расширение для программ 1С:Управление торговлей, 1С:Комплексная автоматизация, 1С:ERP, которое позволяет распечатывать любые печатные формы для непроведенных документов. Можно настроить, каким пользователям, какие конкретные формы документов разрешено печатать без проведения документа.

3480 руб.

22.08.2023    1243    1    4    

3

Переоткрытие внешних обработок

Универсальные функции Платформа 1С v8.3 Бесплатно (free)

На заключительных этапах, когда идет отладка или доработка интерфейса, необходимо много раз переоткрыть внешний объект. Вот один из способов автоматизации этого.

30.11.2023    2433    ke.92@mail.ru    14    

48

Валидация JSON через XDTO (включая массивы)

WEB-интеграция Универсальные функции Механизмы платформы 1С Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    5584    YA_418728146    6    

119

Расширение: Быстрые отборы через буфер [Alt+C] Копировать список, [Alt+V] Вставить список, [Ctrl+C] Копировать из файлов

Инструментарий разработчика Универсальные функции Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

Копирует в буфер значения из списков, из ячеек отчетов, таблиц, настроек списков, других отборов и вставляет в выбранную настройку отбора. Работает с Объект не найден. Работает как в одной так и между разными базами 1С. Использует комбинации [Alt+C] Копировать список, [Alt+V] Вставить список. Также для копирования данных используется стандартная [Ctrl+C] (например из открытого xls, mxl, doc и т.п. файла скопировать список наименований)

1 стартмани

13.10.2022    14504    113    sapervodichka    106    

124

Система контроля ведения учета [БСП]

Универсальные функции Механизмы типовых конфигураций БСП (Библиотека стандартных подсистем) Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

В данном материале рассмотрим типовой алгоритм подсистемы контроля учета БСП в конфигурациях на примерах.

18.07.2022    6694    quazare    8    

108

Хитрости СКД. Часть 3

СКД Универсальные функции Платформа 1С v8.3 Система компоновки данных Конфигурации 1cv8 Бесплатно (free)

Столкнулся с тем, что мне приходится писать гору отчетов. Во многих приходится использовать повторяющиеся приемы. Решил написать шпаргалку, которая, надеюсь пригодится не только мне. В этой статье: Объединение ячеек в отчете только на определенном уровне иерархии, Постобработка итогов в табличном документе, Скрытие колонок в зависимости от количества месяцев в периоде.

28.05.2022    8326    milkers    11    

91