1С:Бухгалтерия 3.0. Как заглянуть в расчет себестоимости отладчиком

22.06.15

Разработка - Механизмы типовых конфигураций

Простой и эффективный метод ознакомления и изучения содержимого временных таблиц, которые мигрируют из функции в функцию через общий МенеджерВременныхТаблиц.

Случилось страшное, и мне пришлось заглянуть в функцию РасчетСебестоимости.РассчитатьСебестоимость(Период, Организация, Ссылка, Режим = "Запасы") из выше означенной конфигурации.

В ней в свою очередь вызывается несколько однотипных процедур, в которые передается ссылка на МенеджерВременныхТаблиц,  и они в нем добавляют (удаляют, меняют) временные таблицы. Иногда хочется посмотреть эти промежуточные результаты во время отладки.

Выходом из ситуации стала функция:

 

Функция ВыполнитьЗапросДляОтладчика(ИсходныйЗапрос,МенеджерВременныхТаблиц) Экспорт
    
    МногоТЗ = Новый Массив;
    
    Запрос = Новый Запрос;
    Запрос.МенеджерВременныхТаблиц = МенеджерВременныхТаблиц;
    Запрос.Текст = ИсходныйЗапрос.Текст;
    
    Для Каждого Элемент Из ИсходныйЗапрос.Параметры Цикл
        Запрос.УстановитьПараметр(Элемент.Ключ,Элемент.Значение);
    КонецЦикла;
    
    Табл = Новый ТаблицаЗначений;
    Табл.Колонки.Добавить("ИмяВРТаблицы");
    Табл.Колонки.Добавить("Колво");
    
    regExp = Новый COMОбъект("VBScript.RegExp");
    RegExp.Pattern = "(ПОМЕСТИТЬ [А-Яа-я0-9_]+)";
    RegExp.Global = Истина;
    RegExp.Multiline = Истина;
    Matches = RegExp.Execute(ИсходныйЗапрос.Текст);
    Для Счетчик = 0 По Matches.Count - 1 Цикл 
        Match = Matches.Item(Счетчик);
        Стр = Табл.Добавить();
        Стр.ИмяВРТаблицы = СокрЛП(СтрЗаменить(Match.Value,"ПОМЕСТИТЬ ",""));
        Стр.Колво = 1;
    КонецЦикла;    
    
    RegExp.Pattern = "(УНИЧТОЖИТЬ [А-Яа-я0-9_]+)";
    RegExp.Global = Истина;
    RegExp.Multiline = Истина;
    Matches = RegExp.Execute(ИсходныйЗапрос.Текст);
    Для Счетчик = 0 По Matches.Count - 1 Цикл 
        Match = Matches.Item(Счетчик);
        Стр = Табл.Добавить();
        Стр.ИмяВРТаблицы = СокрЛП(СтрЗаменить(Match.Value,"УНИЧТОЖИТЬ ",""));
        Стр.Колво = -1;
    КонецЦикла;    
    
    Попытка
        
        Запрос.Текст = ИсходныйЗапрос.Текст;
        
        Табл.Свернуть("ИмяВРТаблицы","КолВо");
        
        Для Каждого Стр Из Табл Цикл
            Если Стр.Колво = 1 Тогда
                Запрос.Текст = СтрЗаменить(Запрос.Текст," "+Стр.ИмяВРТаблицы," ТЕСТТЕСТ_" + Стр.ИмяВРТаблицы);
                Запрос.Текст = Запрос.Текст + Символ(10) + Символ(13) + "; ВЫБРАТЬ * ИЗ ТЕСТТЕСТ_" + Стр.ИмяВРТаблицы;
                Запрос.Текст = Запрос.Текст + Символ(10) + Символ(13) + "; УНИЧТОЖИТЬ ТЕСТТЕСТ_" + Стр.ИмяВРТаблицы;
            КонецЕсли;
		КонецЦикла;        
		       
		МногоТЗ = Запрос.ВыполнитьПакет();
		Для Индекс = 0 по МногоТЗ.ВГраница() Цикл
			Если ТипЗнч(МногоТЗ[Индекс]) = Тип("РезультатЗапроса") Тогда
        		МногоТЗ[Индекс] = МногоТЗ[Индекс].Выгрузить(ОбходРезультатаЗапроса.Прямой);
			КонецЕсли;
		КонецЦикла;
	
      
        
    Исключение
        Сообщить(ОписаниеОшибки());
    КонецПопытки;
    
    Возврат МногоТЗ;
    
КонецФункции   
 

Как использовать ее, наверное, понятно. На всякий случай ...

 

 



Вот, собственно, и все!

См. также

Ценовая власть. Выносим из цикла схему СКД

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

Продолжение темы вынесения кусков повторно-используемого кода в запрос. В прошлый раз мы сделали это с вычислением пользовательских формул. Здесь замахнулись на формулы, задаваемые пользователем запросами.

1 стартмани

11.04.2024    499    tango    0    

3

Формула в реквизите. Приквелл к сериалу "Ценовая власть"

Механизмы типовых конфигураций Платформа 1С v8.3 1С:Управление торговлей 11 Россия Абонемент ($m)

Какому-либо элементу списка сопоставляется числовое значение, зависящее от других значений, причем эта зависимость изменяется от элемента к элементу. Так, в справочнике "Валюты" курс какой-либо валюты может быть задан формулой (или даже запросом) от значения другой валюты. А в справочнике "Виды цен" формула определяет расчет цены для товарной позиции, т.е. элементов справочника "Номенклатура", у которых в карточке указан этот вид цены. А в 1С:ERP, например, этот механизм используется в ресурсной спецификации.

10 стартмани

11.04.2024    385    tango    5    

3

Ценовая власть. Второй сезон

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

В первом сезоне мы рассмотрели (с точки зрения программиста) внутренний механизм, помещающий цены в регистр "Цены". Из этого регистра цена попадает в исходящие УПД (в продажи). Но эта цена (в прайс-листе) дифференцирована (ценообразована) в разрезах свойств самой номенклатуры. Но стратегия ценообразования, ценовая власть - это в первую очередь о работе с ценами для клиента. И тут вступает в дело второй акт марлезонского, Скидки (наценки) и кешбек.

08.04.2024    636    tango    0    

2

Ценовая власть (УТ 11.5) - 2

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

В прошлый раз специальной обработкой мы выбрали объекты УТ 1.5, группируя по подсистемам. Оказалось, что состав подсистем не вполне корректно отображает функциональную структуру, но зато мы нашли процедуру, которая, вроде бы, должна содержать в себе всё, что нас интересует. Обновление цен должно ведь следовать выбранной стратегии ценообразования, верно? Иначе что она обновляет...

06.04.2024    446    tango    1    

1

Ценовая власть или Управление ценообразованием (УТ 11.5)

Ценообразование, анализ цен Механизмы типовых конфигураций Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 11 Россия Управленческий учет Абонемент ($m)

Ценовая власть - это способность (возможность) компании изменять в некоторых пределах отпускную цену своего товара (услуг, продукции). Чем в более широких пределах вы можете играть в цену продажи, тем больше этой власти у вас. Если вы не можете управлять отпускной ценой, то это или не ваш бизнес, или не бизнес вовсе. Здесь в рубрике "База знаний аналитика и руководителя проекта" слово проект не ограничено "проектом в 1С". Посмотрим, что для этого есть в УТ 11.5.

1 стартмани

05.04.2024    534    tango    12    

2

Расширяем возможности дополнительных обработок и настраиваем их отладку

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

Уже не одна веб-страница исписана знаниями о дополнительных обработках, как создать, как подключить. Есть масса вариантов, как их можно отладить. Я разобрался в кишках работы библиотеки и покажу, как можно расширить возможности дополнительных отчетов, а также покажу удобный способ отладки.

07.02.2024    2607    YA_418728146    11    

43

Регистры накопления в 1С:КА2 и 1С:ERP для расчета НДФЛ, страховых взносов и взаиморасчетов с сотрудниками на январь 2024 года. Краткое описание

Зарплата Механизмы типовых конфигураций Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х Россия Бухгалтерский учет НДФЛ Абонемент ($m)

Для расчета зарплаты и соответствующих налогов в конфигурациях 1С:КА2 и 1С:ERP используется 22 регистра накопления, 7 регистров сведений, 1 регистр расчета и бухгалтерские проводки. В таблице приведены названия этих регистров, указаны основные регистраторы и виды движений приход/расход. В описании приводится краткое функциональное назначение регистров в основных зарплатных процессах. Описание регистров родилось из черновиков при написании различных отчетов и обработок при эксплуатации 1С-овских конфигураций и исправлении ошибок по НДФЛ, взаиморасчетов с сотрудниками и прочих. Информация не претендует на полноценное описание работы регистров, скорее это дискуссионный материал. Но, возможно, кому-то пригодится и сократит время при подготовке отчетности за непростой (в плане учета зарплаты) 2023 год. А возможно, кто-то поделится своим опытом.

1 стартмани

10.01.2024    1150    8    2ncom    6    

8

Шаблоны новых объектов 1С для 1С:Бухгалтерии предприятия

Инструментарий разработчика БСП (Библиотека стандартных подсистем) Механизмы типовых конфигураций Платформа 1С v8.3 1С:Бухгалтерия 3.0 Бесплатно (free)

Используются для создания новых объектов в конфигурации, чтобы не забыть, что нужно сделать. Сделано на примере 1С:Бухгалтерия предприятия, в других конфигурациях могут быть другие, а могут быть и похожие объекты.

28.12.2023    4972    mrXoxot    11    

100
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. sergpogo 2 04.06.15 09:51 Сейчас в теме
Добрый день.
Функция ПолучитьВТ(МенеджерВТ, ИмяВТ) Экспорт
 
	Запрос = Новый Запрос;
	Запрос.МенеджерВременныхТаблиц = МенеджерВТ;
	Запрос.Текст = "ВЫБРАТЬ * ИЗ " + ИмяВТ + " КАК ВТ";
	
	Попытка
		Возврат Запрос.Выполнить().Выгрузить();
	Исключение
		Возврат "Ошибка получения временной таблицы: " + ОписаниеОшибки(); 
	КонецПопытки;
 
КонецФункции
Показать

А так не проще?
Krio2; Восьмой; Bassgood; LsrGroup; +4
2. pit201201 85 04.06.15 17:14 Сейчас в теме
(1) spogo,
Остается только посмотреть длинный запрос на несколько экранов и найти ИмяВТ. Потом подставить его в строчку отладчика и ... тот же самый результат.
Я оказался чуть ленивее и ИмяВТ у меня само находится.
JohnyDeath; +1
3. sergpogo 2 05.06.15 12:32 Сейчас в теме
(2)
Остается только посмотреть длинный запрос на несколько экранов и найти ИмяВТ.
или нажать CTRL+F и найти "ПОМЕСТИТЬ"

пысы: ничего не имею против вашего способа.
+
4. pit201201 85 05.06.15 12:59 Сейчас в теме
(3) spogo,
... а потом проверить не удалилась ли она в середине текста. Обратно же просто - СTRL-F. На листочек выписываем временные таблицы которые есть, потом вычеркиваем - которые удалены. А потом нажимаем Shift-F9 и переписываем с листочка ПолучитьВТ(Менеджер, ИмяВТс Листочка).
Зачем все это делать, когда можно не делать, а дать поручение сделать это за тебя.
В общем, я допускаю когда на кнопках клавы WASD надписи стерты, а потертые кнопки Ctrl и F мне не нравятся. :)
+
5. RustIG 1556 14.06.15 20:31 Сейчас в теме
(0) вопросы: у вас только одна временная таблица выгружается в ТЗ? А если запрос содержит несколько временных таблиц? Какая из них выгрузится в таблицу значений? Как в отладчике выбирать как запрос анализировать? и почему бы при отладке не проверить временные таблицы, которые в дальнейшем - после использования - будут уничтожены?
предложение: консоль запросов позволяет обрабатывать только часть выделенного текста в запросе. Я использую эту возможность при просмотре результата временных и вложенных таблиц или при редактировании только части запроса, входя в конструктор выделенного текста запроса.
Для просмотра временных таблиц следует закомментировать выражение «Поместить», выделить часть текста запроса и нажать «Выполнить». После просмотра следует не забыть удалить комментарии в строке «Поместить»
+
6. pit201201 85 22.06.15 12:39 Сейчас в теме
(5) Rustig,
маленько подправил текст процедуры
МногоТЗ = Запрос.ВыполнитьПакет();
...

теперь на выходе имеем массив таблиц значений в каждую из которых можно заглянуть.

Уничтожаемые в запросе таблицы можно и оставлять для анализа, появится необходимость доработаю.

Остался небольшой косяк : слова ПОМЕСТИТЬ и УНИЧТОЖИТЬ должны быть написаны в исходном запросе БОЛЬШИМИ буквами.
+
7. pit201201 85 22.06.15 12:49 Сейчас в теме
(5) Rustig,
Против консоли запросов ничего не имею и сам активно использую ее. В предложенном Вами варианте затруднение (замедление процесса поиска багов) возникает при передаче параметров. Еще мне не совсем понятно как консолью отладить запрос в котором используется ВременнаяТаблица из другого запроса. Предложенная процедура это своего рода экспресс анализатор текущего состояния МененджераВременныхТаблиц.
+
8. bforce 481 25.06.15 07:38 Сейчас в теме
Для просматра временных таблиц написано много разных фунцкий, в том числе, в типовых попадаются. Но я ставлю плюс за использование регулярных выражений.
+
Оставьте свое сообщение