Интерактивный анализатор больших и вложенных запросов "Парсер запросов"

Публикация № 175202

Разработка - Практика программирования

86
С "Парсером запросов" даже самый сложный и длинный запрос анализируется, проверяется и исправляется за считанные минуты. Запрос перестал быть "черным ящиком" и может быть проверен по-шагам в конфигураторе.

Обработка "Парсер запросов" - трехкомпонентный программный комплекс, ориентированый на специалистов по внедрению и опытных пользователей.

Данная обработка предназначена для :

1. По-компонентного анализа и корректировки текстов на языке запросов 1С.

2. Экспресс анализа запроса в режиме отладки программного кода 1С, без изменения содержимого менеджера временных таблиц.

3. Создание файла- "снимка" запроса *.sel в режиме отладки программного кода 1С для последующего автономного анализа запроса.

4. Выполнение системных трансформаций текстов запросов, а именно:

- декомпозиция пакета вложенных запросов в пакет запросов без вложенности с передачей данных через временные таблицы;

- "сквозное" переименование временных таблиц;

- контролируемое удаление запросов из пакета запросов и подзапросов в объединении запросов;

5. Интеграция с Консолью запросов.

86

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

Наименование Файл Версия Размер
Парсер запроса v2.16.b
.epf 150,70Kb
15.08.13
158
.epf 150,70Kb 158 Скачать

Специальные предложения

Комментарии
Избранное Подписка Сортировка: Древо
1. Famza 82 25.02.13 11:27 Сейчас в теме
(0) Может описание более развернуто сделать?
2. German 870 25.02.13 12:42 Сейчас в теме
oOO неожиданно парсер и лексер на языке 1С, только на первый взгляд лексем маловато
GoldParser, Antlr - не не слышал?
+ за декомпозицию во временные, еще не было
kuntashov; +1 Ответить
3. bwlg 89 25.02.13 13:36 Сейчас в теме
Пишите "хотелки" и найденные ошибки. Будет новая версия (уже beta), будет более подробное описание в Help (Кстати, читали help ?), будет конвертация пакета в запросы с максимальной вложенностью.
Главное - пишите разборчиво, что доделать и что поправить.

ЛЕКСЕМ (точнее терминальных символов) столько, сколько нужно было для именно этой задачи.

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

Кажется по скорости удалось сделать что-то приемлемое на языке 1С. Очень много сил ушло на оптимизацию по скорости.

На Мисте посмотрел GoldParser, Antlr - это немного другое.

По сравнению Консолью запросов из "Подсистема "Инструменты разработчика" v2.69", позволяет делать "снимки" запросов в виде файла *.sel и далее их использовать почти в любой консоли запросов, не требует регистрации COM библиотеки.
5. makfromkz 8 27.02.13 06:12 Сейчас в теме
(3)
На Мисте посмотрел GoldParser,

Я поиском не нашел там :(
не подскажите ссылку, плииз :)
6. makfromkz 8 27.02.13 06:24 Сейчас в теме
(3) ЧТД?
// Копирует дерево запросов
//
// Параметры:
//  ИсходноеДерево
//	НовоеДерево.
//
Процедура вСкопироватьДеревоЗапросов(ИсходноеДерево, НовоеДерево, КолонокВДереве)
	
	НовоеДерево.Строки.Очистить();
	
	Если ИсходноеДерево.Строки.Количество() = 0 Тогда
		Возврат;
	КонецЕсли;
	
	Для каждого СтрокаДерева из ИсходноеДерево.Строки Цикл
		
		НоваяСтрока = НовоеДерево.Строки.Добавить();
		
		Для сч = 0 по КолонокВДереве - 1 Цикл
			НоваяСтрока[сч] = СтрокаДерева[сч];   // <=== тут ошибка, её текст ниже
		КонецЦикла;  
Показать

текст ошибки возникающей при открытии обработки:
{Форма.Форма.Форма(655)}: Индекс находится за границами массива
НоваяСтрока[сч] = СтрокаДерева[сч];
14. v.l. 28.02.13 10:20 Сейчас в теме
(3) bwlg, хотелка - есть версия для 8.1 или самому перевести?
4. German 870 25.02.13 15:14 Сейчас в теме
На Мисте посмотрел GoldParser, Antlr - это немного другое.

А ну тогда действительно)

Понятно что они текст запроса 1С не разбирают

Выбрать Таб.* ИЗ Таб
7. bwlg 89 27.02.13 09:35 Сейчас в теме
Индекс находится за границами массива НоваяСтрока[сч] = СтрокаДерева[сч];


У меня за месяц эта ошибка не возникала. Причина ошибки, только одна - неверный формат файла (колонок в файле *.sel больше 7).

Можно исправить так
 //строка 703 
// Было
	вСкопироватьДеревоЗапросов(ПолученноеЗначение, ДеревоЗапросов, ПолученноеЗначение.Колонки.Количество());
// Стало
	вСкопироватьДеревоЗапросов(ПолученноеЗначение, ДеревоЗапросов, Мин(ПолученноеЗначение.Колонки.Количество(),7));


Спасибо за сообщение, эта ошибка исправлена в очередном релизе
8. bwlg 89 27.02.13 09:41 Сейчас в теме
Я поиском не нашел там :(


Надеюсь правила форму не нарушаю ..
http://yandex.ru/yandsearch?text=GoldParser%2C+Antlr&lr=38

Там и Миста и Wikipedia
9. Darth_Anyan 27.02.13 10:36 Сейчас в теме
Скормил обработке запрос с подзапросом в условии ГДЕ (запрос бессмысленный-тестовый):

ВЫБРАТЬ
 Контрагент.ИНН
ИЗ
 Справочник.Контрагенты КАК Контрагент
ГДЕ
 Контрагент.Ссылка В
   (ВЫБРАТЬ
    Справочник.Контрагенты.Ссылка
   ИЗ
    Справочник.Контрагенты)
Показать


Преобразование во временные таблицы отработало следующим образом:

ВЫБРАТЬ
    Справочник.Контрагенты.Ссылка
    ПОМЕСТИТЬ Запрос_1afa415bad78447bac6cca9c159a848d
ИЗ
    Справочник.Контрагенты
;

////////////////////////////////////////////////////////////­////////////////////
ВЫБРАТЬ
 Контрагент.ИНН
ИЗ
 Справочник.Контрагенты КАК Контрагент
ГДЕ
 Контрагент.Ссылка В
   Запрос_1afa415bad78447bac6cca9c159a848d
Показать


По идее, подзапросы из условий отбора/соединения надо либо не трогать (что просто технически, но спорно методически), либо преобразовывать во внутреннее соединение (наоборот).
Itilive.ru; +1 Ответить
10. bwlg 89 27.02.13 12:16 Сейчас в теме
Именно по этой причине еще нет трансформаций из временных таблиц во вложенные.

При трансформации нужно учитывать еще тип запроса, в том числе коррелированные запросы. В вашем запросе именно такой случай, Запрос_1afa415bad78447bac6cca9c159a848d потенциально может быть коррелированным (т.е. выполняться многократно). В 2.10 постараюсь сделать разбор конструкций В () и В ИЕРАРХИИ () для определения потенциально коррелированных запросов. Полагаю, что факт коррелирования установить не получится, так как для этого пришлось бы полностью разбирать конструкции ВЫБОР, и следить за метаданными конфигурации.

ИТОГО: Спасибо за сообщение. Будет исправлено в версии 2.10. Остальным рекомендую до выхода 2.10 пока не пользоваться трансформациями. 2.10 примерно в понедельник
11. DAnry 6 27.02.13 13:33 Сейчас в теме
Очень интересный, оригинальный, подход к проблеме. ...опробуем
12. bulpi 158 27.02.13 15:16 Сейчас в теме
Это очень круто. Но, для того, чтобы пользоваться можно было юзерам не таким умным, как автор (например, мне), нужен более развернутый help, а лучше с простыми примерами.
13. bwlg 89 27.02.13 17:06 Сейчас в теме
На написание этого help у меня ушло 2 дня. Более объемный help - это время, которого просто нехватает.

Весь help можно расписать так.

1. Запустить ПарсерЗапроса (просто открыть в 1С Предприятие). Дальше как в Консоли запросов, только есть второе маленькое окошко навигации по запросу. В ПарсереЗапросов можно редактировать любую маленькую часть запроса, не пугаясь "километровых" запросов. Если не знаете как работать с Консолью запросов - то эта обработка точно Вам не нужна.

2. Хотите "продвинутую" выгрузку в консоли запросов ? Нажмите кнопку "Консоль запросов" и пользуйтесь этой обработкой. Можно из макета "Консоль запросов" сохранить как *.epf файл и пользоваться этой консолью запросов.
Что "крутого" в этой консоли ? Не надо просматривать временные таблицы, просто выбираем способ выгрузки "Анализ" и получаем все результаты временных и вложенных таблиц в виде одного дерева.

Хотите "прокачать" Консоль запросов, которая у Вас есть и Вам нравится - читаем help и соответствующий макет.

3. Нужен экспресс-анализ запроса под отладкой? Первое, решаем, где лично Вам удобно хранить файл "снимка" запроса. Второе, в Парсере запросов, меню сервис -> Получить код VLF. Программа спросит имя, под которым будет сохраняться "снимок" запроса и выдаст Вам готовый код для вставки в глобальный/общий модуль. Скопировали с окна, вставили в конфигурацию. Все, пользуемся.
Просто посмотреть запрос в Табло VLF(Запрос).
Посмотреть и сохранить VLF(Запрос,1)

Все
s.w.a.t.; brunen9; teflon; +3 Ответить
15. bwlg 89 28.02.13 11:58 Сейчас в теме
16. tormozit 5635 28.02.13 14:31 Сейчас в теме
Декомпозиция во временные таблицы по одному подзапросу уже давно есть в консоли запросов ИР.

Кстати в ней же есть
1. По-компонентный анализ и корректировка текстов на языке запросов 1С.
2. Экспресс анализа запроса в режиме отладки программного кода 1С, без изменения содержимого менеджера временных таблиц.
3. Создание файла - "снимка" запроса *.sel и элемента справочника "Объекты для отладки" в режиме отладки программного кода 1С для последующего автономного анализа запроса.
4. Выполнение системных трансформаций текстов запросов, а именно:
- Декомпозиция во временные таблицы по одному подзапросу;
5. Не нужно интегрироваться с Консолью запросов.
Прикрепленные файлы:
brr; brunen9; artbear; +3 Ответить
17. Darth_Anyan 28.02.13 14:46 Сейчас в теме
(16) tormozit,

при всем безграничном уважении к ИР, у них есть архитектурная особенность - требуется регистрация GoldParser (ну и доступ к WSH и WinAPI), в результате, работая в терминалке заказчика с порезанными донельзя правами, можно остаться без инструментария. Представленный механизм служит очень мощным дополнением как раз для таких случаев. По крайней мере, я так выстроил для себя их использование - если есть возможность, встраиваем ИР, если нет - достаем мобильную версию от khaoos, если совсем нет - Парсер запросов.
18. tormozit 5635 28.02.13 14:56 Сейчас в теме
(17) Все так. Я собственно просто отметил, что почти все фичи реализованные здесь, давно уже отточены в консоли запросов ИР. Просто автор видимо не знал об этом и потому не упомянул в публикации. Я решил явно указать на это для тех, кто не в курсе.
Необходимость админских прав для регистрации ряда вспомогательных dll в ИР конечно же является самым большим неудобством.
19. Darth_Anyan 28.02.13 15:22 Сейчас в теме
(18) Вообще, идеальным видится объединенное решение на базе ИР с переключением между движками, но это уже мечты о всеобщем благорастворении воздухов...
20. bwlg 89 28.02.13 15:40 Сейчас в теме
Вообще-то автор о всем сказанном уже упомянул
По сравнению Консолью запросов из "Подсистема "Инструменты разработчика" v2.69", позволяет делать "снимки" запросов в виде файла *.sel и далее их использовать почти в любой консоли запросов, не требует регистрации COM библиотеки.

А об ИР до этого комментария действительно не знал.

Было бы интересно эти два инструмента сдружить. Это пока заочный вопрос к автору ИР
21. tormozit 5635 28.02.13 19:15 Сейчас в теме
У меня в консоли запросов ИР используется грамматика языка запросов 1С. К ее правилам привязан анализ построенного парсером GoldParser синтаксического дерева. Соответственно чтобы избавиться от необходимости подключать GoldParser.dll нужно написать NATIVE компоненту, которая бы имела примерно тот же интерфейс, что и COM объект из GoldParser.dll. Делать это у меня пока нет времени. Возможно сделаю в будущем.

Использовать неполное синтаксическое дерево, построенное по наверняка неявной грамматике из этой обработки, где все правила называются по-своему - не очень привлекательная идея. Любой баг в таком парсере, кажется, будет исправляться все сложнее и сложнее с неизбежным ростом числа и сложности конструкций.
Матрос; +1 Ответить
22. bwlg 89 28.02.13 21:49 Сейчас в теме
На самом деле у меня не стояла цель написать полный компилятор. Хотелось просто сделать хороший инструмент для себя и друзей.

Сейчас скачал грамматику и по заголовку понял, что это Вы писали ИР.
Лексический анализатор для разбора программных модулей 1С необходимо доделать. В запросах не бывает многострочных строковых констант. Синтаксический разбор ведется по БНФ. Грамматику языка запросов брал из документации к 1С (как не странно, хорошо описана в файле ЕСИС8.0), терминальные символы взяты из книг по языку 1С (стр 2870).

Давайте так: вы определяетесь с техническими требованиями, и пообщаемся вне этого форума. В help мой адрес есть. На выходных я буду в Skype, постучусь. До связи.
23. Gilev.Vyacheslav 1839 02.03.13 13:29 Сейчас в теме
я пока не понял, зачем бессмысленно загонять все во временные таблицы, но плюс поставил авансом и скачал, вдруг придет озарение )
24. bwlg 89 02.03.13 17:17 Сейчас в теме
Это инструмент анализа (больших) запросов. Иногда удобнее читать и отлаживать запрос в виде последовательности временных. Другими словами, это дополнительный инструмент, удобный тогда, когда он нужен.
25. Gilev.Vyacheslav 1839 02.03.13 20:11 Сейчас в теме
а я то дурак планы запросов смотрю...
26. tormozit 5635 02.03.13 20:21 Сейчас в теме
(25) План запроса смотрят при "техническом" исследовании запроса, когда нужно понять почему так долго, как ускорить и т.д. Автор же пишет о "логическом" исследовании запроса, когда нужно "по шагам" понять как логически работает чужой запрос или почему он выдает неверный результат
krv2k; kuntashov; bwlg; German; +4 Ответить
27. 1cmax 151 03.03.13 20:38 Сейчас в теме
есть ли преимущества перед консолью от Tormzit?
28. bwlg 89 04.03.13 08:21 Сейчас в теме
Размещена версия 2.10beta. Исправлены ошибки:
1. Вложенный запрос в конструкции В и ИЕРАРХИИ не выносится во временные, о чем выдается сообщение.
2. Не приводит к сбою загрузка файла *.sel с количеством колонок более 7.
3. Устранена ошибка, связанная с некорректным поведением платформы ( в табло, подзапросы-объединения разбирались в бесконечную вложенность подзапросов. Вне Табло - все работало корректно). Версия обозначена как beta.
4. Добавлена метка версии в локальном help функции VLF().
5. Дописан help Парсера запросов.

В ближайший месяц новых версий не будет. Попробую написать полный компилятор на правилах для использования, возможно, в "Инструменты разработчика".
29. zba 48 06.03.13 18:24 Сейчас в теме
30. blockcode 32 06.03.13 23:08 Сейчас в теме
Кстати, необходимость разбивки сложных запросов мне тоже пришлось решать))) Правда я обошелся двумя кнопками, которые добавил на чужую консоль запросов))) http://forum.infostart.ru/forum24/topic20163/message861068/#message861068
31. bwlg 89 07.03.13 09:43 Сейчас в теме
В Парсере запросов, точнее функции VLF есть весьма оригинальный глюк. Вопрос задаю на случай, может кто что подскажет.

Если VLF() вызывается в любом модуле, например,
Запрос.Текст = "******";
Запрос.Выполнить();
СтруктураРезультат = VLF(Запрос);


то в СтруктураРезультата находится нормальный ответ.

Если VLF(Запрос) вызывается в табло ( а так отладить код по шагам нельзя), то появляется очень оригинальный глюк.
Запрос +
        --- Объединение +
                         ---- Запа4451213с425232213423+
                                                       ------ Запр7сс6723ааааа

Подветка "ТекстЗапроса" (смотри далее) вообще не добавляется.

И так до бесконечности, как будто в структуру с ключем "ЗапрУИД" добавляется структура с ключем "ЗапрУИД2" в нее следующая, в нее следующая .... Постоянно генерируется новый УИД.

При выходе релиза 2.10 причина ошибки условно была найдена.
Вложенная структура создается кодом
// До
ВложСтруктура = новый Структура;
ВложСтруктура.Вставить("ТекстЗапроса",ТекстЗапроса);

// в 2.10
ВложСтруктура = новый Структура("ТекстЗапроса",ТекстЗапроса);

Но это заработало только на тестовом примере.
В реальной базе глюк повторяется. Еще раз повторю, ТекстЗапроса даже в 2.10 НЕ ДОБАВЛЯЕТСЯ!
Попытался сделать так
ВложСтруктура = новый Структура;
ВложСтруктура.Вставить("ТекстЗапроса",ТекстЗапроса);
ВложСтруктура.Вставить("Тест",СтрокаТаблицыЗначений);


И тут платформа честно призналась, что это ее глюк
А именно, когда просматриваешь, в табло указывается, что "Тест" - это строка таблицы значений. Как только пытаешься ее просмотреть - она вдруг становится бесконечно вложенной структурой, на очередном ее уровне, тест - строка таблицы значений, при попытке ее просмотреть - становится структурой и т.д.

Характерно, что этот глюк появляется только в ветке "Объединение" и почти всегда. Ветка "Вложенные" формируется этим же фрагментом программного кода, но в ней глюка нет.

Я попытался "Объединение" переименовать в "Я_Объединение" - результата не дало. Попытался именовать ключ не
в виде "Запр + СтрЗаменить(УИД, "-","")", а в виде "Запр + СтрЗаменить(УИД, "-","nnnn")" - результата не принесло, хотя в каждом новом вложении УИД генерируется по алгоритму "Запр + СтрЗаменить(УИД, "-","nnnn")".
НО ! код в ветке "Объединение" в принципе не рекурсивный

Напоследок привожу сам код
Если НомерФункции = 4 Тогда  // Разбор и  выполнение  подзапросов
			
	Для каждого Подзапроса Цикл
	   Название = "Запр"+СтрЗаменить(Новый УникальныйИдентификатор,"-","");
           УпрощенныйТекстЗапроса = ДатьУпрощеныйТекстЗапроса(Подзапрос);
           ДекоративныйТекстЗапроса = ДатьДекоративныйТекстЗапроса(Подзапрос);
		
	   ВложСтруктура = Новый Структура("ТекстЗапроса",ДекоративныйТекстЗапроса);
			
		Если НЕ ПустаяСтрока(УпрощеныйТекстЗапроса) Тогда
			Запрос.Текст = УпрощеныйТекстЗапроса;
			Попытка
				ТЗ = Запрос.Выполнить().Выгрузить();
				ВложСтруктура.Вставить("Результат_Кол_"+
				Формат(ТЗ.Колонки.Количество(),"ЧЦ=3; ЧГ=0")+
				"_Стр_"+ 
				?(ТЗ.Количество()=100,"более99",Формат(ТЗ.Количество(),"ЧЦ=3; ЧН=Пусто; ЧГ=0")), ТЗ);
			Исключение
			
			   ВложСтруктура.Вставить("ОшибкаВыполненияЗапроса",ОписаниеОшибки());
			   ВложСтруктура.Вставить("ФактическиВыполняемыйЗапрос",УпрощеныйТекстЗапроса);
			КонецПопытки;
		КонецЕсли;
			
		// упрощено для случая - 1 подзапрос:	
		Если Подзапрос.ТипБлока = _Вложенный Тогда
			ТекВеткаСтруктуры.Вставить("Вложенные", Новый Структура(Название,ВложСтруктура));
			Библиотека(4,стр,ВложСтруктура,Запрос,***); // вызываем себя
                    Возврат 0;
		ИначеЕсли Подзапрос.ТипБлока = _Объединение  Тогда
		       ТекВеткаСтруктуры.Вставить("Объединение", Новый Структура(Название, ВложСтруктура));		
                    Возврат 0;			
		КонецЕсли;
	КонецЦикла;
		
КонецЕсли;

Показать


Еще раз напоминаю, что весь код при вызове НЕ В ТАБЛО, отрабатывается БЕЗ ОШИБОК. Поэтому прошу не искать ИМЕННО ОШИБОК в коде вверху. Это сильно упрощенный пример, необходимый для демонстрации ЛОГИКИ работы кода.
32. tormozit 5635 07.03.13 09:48 Сейчас в теме
(31) Сделаешь багрепорт для 1с? Если не франч, то я могу отправить.
33. bwlg 89 07.03.13 09:50 Сейчас в теме
34. margo_m09 28.03.13 07:11 Сейчас в теме
хорошая идея, сразу понравилась обработка, даже если и есть какие недочеты пока при использовании, не заметили))))
35. so-quest 130 19.06.13 14:56 Сейчас в теме
На правах рекламы. Если не нравиться таскать за собой голдпарсер то вот есть решение - http://infostart.ru/public/186724/ осталось только грамматику выбрать и прикрутить.
36. so-quest 130 19.06.13 14:57 Сейчас в теме
Не пугайтесь что там вывод в ХМЛ - код открыт и вывод можно сделать куда угодно (массив, структура и т.д.)
37. bwlg 89 19.06.13 15:18 Сейчас в теме
Недочеты есть. В основном это "снимок" запроса. Не все типы данных удается вытаскивать в файл.
Второй недочет - ограничение выборки в 100 записей. Иногда это здорово вводит в заблуждение.
Постараюсь в ближайшее время выложить новую версию.
38. prodines 107 04.07.13 16:16 Сейчас в теме
Не открывается консоль запросов для sel-файла. Пишет:


Консоль запросов недоступна. Форма.Форма.Форма(283) Поле объекта не обнаружено. (ВнешнийЗапрос)

ЗЫ Да ерунда это всё - все эти консоли запросов и парсеры - анализаторы. Всё это НЕ работает в полной мере - и никогда не заработает...
39. bwlg 89 05.07.13 08:27 Сейчас в теме
В тексте ошибки на русском языке написано "Консоль запросов недоступна."

Консоль запросов - это внешний файл для Парсера. Смотри и читай документацию.
Эта ошибка может происходить, если в макете хранится файл консоли несоответствующий описанию. Замените в макете (он там один) на ту консоль, которая у Вас работает.

Если у Вас ВСЕ НЕ работает и НИКОГДА НЕ заработает - то значит такая карма. Даже не пытайтесь пользоваться всякими парсерами и консолями.
40. bwlg 89 05.07.13 08:43 Сейчас в теме
Вероятная ошибка:

При запуске консоли макет сохраняется в файл. По какой-то причине файл не создан или не открывается (нет места на диске, нет прав на папку). Парсер не смог открыть сохраненный файл, поэтому выдал такое сообщение.
41. prodines 107 05.07.13 09:17 Сейчас в теме
(40) bwlg,

Если будет время - попробую поковыряться. Но пока его нет.
Если у Вас ВСЕ НЕ работает и НИКОГДА НЕ заработает - то значит такая карма. Даже не пытайтесь пользоваться всякими парсерами и консолями.

Я перебрал штуки 3-4 всяких запросников-консолей и т.п. с этого сайта - и ни один пока что с моим конкретным запросом не заработал (причем вообще не сработал). А штатная консоль запросов - работает, просто у неё мало возможностей.

Да, и у меня тоже возникла ошибка, когда при объединении вложенных подзапросов открываешь их (в отладчике) - а там ещё вложенные - в них ещё вложенные - и так до бесконечности. А мне как раз нужно было в них посмотреть, что там происходит.

Вообще-то я только от Вашей разработки добился ну хоть какого-то толка - в отличие от аналогов на этом сайте. Просто под отладкой смотреть запрос и очень медленно, и не очень наглядно - вот я и хотел через консоль глянуть, как было в хелпе заявлено.
43. prodines 107 05.07.13 14:27 Сейчас в теме
(40) bwlg,

В Вашей обработке в макете "КонсольЗапросов" содержится ... сама эта же обработка. :) А вот в ней уже есть макет "КонсольЗапросов3" - вот там только и есть консоль запросов. Я поправил это - и консоль стала нормально запускаться из парсера. :)

Способ выгрузки "Анализ" - хорошая вещь. Видно всё то же самое, что и в отладчике - только нет вложенной бесконечной зацикленности (когда есть объединение вложенных подзапросов) и скорость работы отменная - не то, что эти дикие тормоза в отладчике.

Только почему-то вложенные запросы не разбираются до конца? А тогда какой смысл в Вашей разработке?

Что мне теперь делать? Надо посмотреть все вложенные запросы - а я не могу...

ЗЫ А как вообще просматривать вложенные подзапросы стандартной консолью запросов? Я так и не понял... Там ведь нет способа выгрузки "Анализ".
42. bwlg 89 05.07.13 10:04 Сейчас в теме
По бесконечному вложению запросов информация отправлена в 1С. Обещали исправить. Будем ждать.
Эта ошибка меня тоже напрягает. Возможно в очередном релизе я ее обойду. Пока у меня тоже очень мало времени.

Смотреть запрос под отладчиком - просто не о чем. Парсер ускоряет отладку в десятки раз.

Ошибок пока в Парсере много. (Забавно, что даже в нативном конструкторе запросов ошибок много.)
Примерный список предстоящих доработок:
1. Ограничение 100 записей на выборку часто вводит в заблуждение. Буду подымать до 500.
2. Использование ограничения на 100 записей в подзапросах отрубает оптимизацию. Иногда в больших запросах это приводит к зависанию (буду переписывать сборку запроса).
3. Не везде стоит ограничение на 100 записей. Например, когда раскрываешь ветку "Вложенные". Где-то просмотрел.
4. В "снимке" запроса "заглушки - пустые таблицы" из параметров буду менять. В полях запроса нужно возвращать конкретные типы данных.
5. Массив в параметре запроса не сохраняется в файле sel. Поэтому почти все разработчики массив меняют на список значений. Но список запросов нельзя передавать при расчете базы. Там должен оставаться массив строк.
6. Бесконечное вложение объединения. Буду переходить на свой алгоритм генерации уникального имени.
7. В функцию VLF планирую добавить итератор по выборке и результату запроса. Функции типовых алгоритмов часто возвращают переменные, содержимое которых надо посмотреть.

Если кто нашел еще какие ошибки - пишите. Жду.
44. bwlg 89 05.07.13 15:36 Сейчас в теме
Анализ есть в выпадающем списке. Файл сегодня обновлю
45. bwlg 89 08.07.13 09:02 Сейчас в теме
Обновил. Большинство описанных выше ошибок устранил.
Не устранено: массив для расчета по базе. Это нужно менять в консоли запросов.
Тестируйте. Пишите замечания.

Изменено: Новое имя формируется не через УИД, а через генератор случайных чисел.
Это позволит уйти от ошибки платформы - бесконечного вложения.
46. bwlg 89 09.07.13 19:09 Сейчас в теме
Максимально упростил текст, чтобы довести ситуацию до сути (до абсурда).

"Лесенка" в структуре, что описана выше, сохраняется вплоть до кода:

Перем ГенераторСЧ;

Процедура КнопкаСформироватьНажатие(Кнопка)
	х = VLF_();
КонецПроцедуры


Функция VLF_()
		 	
	
	Возврат новый Структура(
	
	"Запр" + Формат(ГенераторСЧ.СлучайноеЧисло(),"ЧГ=0"),
	
	Новый Структура("Тек","аа")
	
	);					
			
КонецФункции

  ГенераторСЧ = новый ГенераторСлучайныхЧисел(Секунда(ТекущаяДата()));
Показать
47. vec435 15 10.07.13 10:11 Сейчас в теме
А если набор временных таблиц запроса формируется не в одном блоке кода , а последовательно - можно ли "собрать" его в одно дерево? И 2 вопрос: можно ли построить дерево "родословных" для временных таблиц?
48. bwlg 89 10.07.13 12:22 Сейчас в теме
При формировании "снимка" содержимое временных таблиц сохраняется в sel.
Родословную в пределах запроса видно по ответу функции.
Анализ программного кода для сбора предыдущих таблиц, а также "накопление" снимков в один файл - не планируется.
49. bwlg 89 10.07.13 14:10 Сейчас в теме
Ура! "Лесенку" раскрытия запроса победил.

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

Выкладываю новую версию.
50. Shade 2 22.07.13 13:17 Сейчас в теме
Да, потенциал очень большой, разбираться и разбираться, спасибо, думаю пригодится в работе!
51. bwlg 89 13.08.13 08:54 Сейчас в теме
Обновление:
1. Добавлено окно информации, которое в настройках может быть отключено.
В окне информации выводится: место ошибки в запросе, входящие таблицы. Для исходящей указываются имена запросов, в которых эта таблица используется.
2. Устранена ошибка при конвертации запроса из вложенного во временные таблицы (неверное место конструкции ПОМЕСТИТЬ)
3. Устранена ошибка 15-го релиза (не сохранялся "снимок запроса" если использовались временные таблицы).
4. Изменен алгоритм получения запроса из построителя. Раньше запрос собрался по частям: отдельно текст запроса, отдельно параметры. В 16 релизе принято решение перейти на функцию ПолучитьЗапрос().
52. alkar 90 15.08.13 14:26 Сейчас в теме
Ругается!
{Форма.Форма.Форма(335,8)}: Процедура или функция с указанным именем не определена (VLF)
х = <<?>>VLF();
53. bwlg 89 15.08.13 14:46 Сейчас в теме
Заменить строку 335 на
х = ""; Выполнить("х = VLF();");


Сейчас файл обновлю.
54. alkar 90 15.08.13 15:53 Сейчас в теме
(53) bwlg, Ок. Работает спасибО!
55. lelusha 05.02.14 16:22 Сейчас в теме
Уточните, пжл, а будет ли работать на 8.2?
56. bwlg 89 06.02.14 09:38 Сейчас в теме
Работает на любой 8-ке. Сам пользуюсь на 8.1, 8.2 и 8.3.
57. Virgiliy 7 13.03.14 09:44 Сейчас в теме
Добрый день!

При открытии ошибка...
Прикрепленные файлы:
58. bwlg 89 13.03.14 13:55 Сейчас в теме
Для Virgiliy 13.03.2014 09:44

Это не ошибка. Это уведомление, что код не добавлен в конфигурацию. Так задумывалось.
59. Virgiliy 7 13.03.14 13:59 Сейчас в теме
(58) bwlg,
Я что-то где-то упустил... наставьте на путь истинный (подскажите код) :)
60. Virgiliy 7 13.03.14 14:22 Сейчас в теме
61. TIG-PROGRAMMIST 49 26.09.14 18:45 Сейчас в теме
Работает спасибо коллега...
62. AlexO 128 14.01.15 10:00 Сейчас в теме
Все равно не понял, как это помогает писать запросы. Что анализируется, и как результаты этого "анализа" помогут исправить что-то в запросе/модифицировать его - без понимания смысла написанного.
А если есть понимание - то как тут поможет анализатор, если и так понимаешь, где ошибка, где - нужна оптимизация, и все напишешь вручную?
63. bwlg 89 06.07.15 16:16 Сейчас в теме
(62) AlexO, понимание - это хорошо. А если это чужой запрос на 10 тыс строк?
Оставьте свое сообщение

См. также

Описание формата внутреннего представления данных 1С в контексте обмена данными 153

Статья Программист Внешняя обработка (ert,epf) v8 v8::УФ 1cv8.cf Абонемент ($m) Практика программирования Внешние источники данных Разработка

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

1 стартмани

06.09.2019    6449    6    Dementor    27       

1СПАРК РИСКИ. Сервис оценки благонадежности контрагентов. Промо

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

Вам нравятся запросы в 1С? 14

Инструменты и обработки Программист Конфигурация (md, cf) v8 v8::Запросы 1cv8.cf Абонемент ($m) Практика программирования Разработка

Речь не только о том, что простейший запрос с "легальным" оформлением растянется на пол-экрана, речь еще обо всем, что нужно написать "в нагрузку" к тексту запроса. Все эти "Новый Запрос", "УстановитьПараметр" и последующие пляски с обработкой результата... Пора с этим заканчивать!

1 стартмани

03.07.2019    11184    1    m-rv    79       

1С:Ассемблер. Немного летнего веселья! 312

Статья Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Практика программирования Разработка

Все вы, наверное, слышали, что 1С-ники жалуются на свою систему, считая язык 1С недостаточно низкоуровневым, скучным и т.п. Все они с тоской поглядывают в сторону "настоящих" языков программирования. Так вот, господа, они неправы. В системе 1С есть места, где можно размять программерский мозг и получить удовольствие от низкоуровневой техники. Предлагаю вам погрузиться в недра виртуальной машины 1С и понять, как она работает. Там есть свой "ассемблер" и мы попробуем его в действии!

1 стартмани

21.06.2019    15715    48    Evil Beaver    116       

Онлайн-интенсив "Бизнес-процессы для подготовки к экзамену 1С:Специалист по платформе" 12 декабря 2019 г. Промо

На интенсиве будут рассмотрены все теоретические вопросы, связанные с устройством механизма бизнес-процессов – это необходимо для успешной сдачи экзамена 1С:Специалист по платформе. Также, в качестве практического примера, будет решена задача, аналогичная экзаменационной.

777 рублей

Простые примеры сложных отчетов на СКД 269

Статья Программист Архив с данными v8 v8::СКД 1cv8.cf Абонемент ($m) Практика программирования

Подписи в отчете. Особенности соединения наборов: как соединить несоединяемое. Остатки на дату и обороты по месяцам в одном отчете. Курс валюты на каждую дату без группировок и соединений в запросе. Отчет с произвольными колонками и с произвольной последовательностью. "Неадекватный отчет".

1 стартмани

12.06.2019    15301    11    Hatson    22       

Безопасная работа с транзакциями во встроенном языке 189

Статья Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования

Разбираемся с опасностями использования транзакций во встроенном языке 1С. Познаем ошибку "В данной транзакции уже происходили ошибки". Учимся защищаться от них.

1 стартмани

25.03.2019    17081    8    tormozit    44       

Cashback 35% при покупке 1С лицензий на счет INFOSTART.RU с 27.11 по 04.12 Промо

Оформляете заказ на 1С лицензии или конфигурации. Получаете 35% от стоимости на счет в профиле INFOSTART.RU. Выбираете сервисы и продукты на сумму кэшбэка.

Баг или фича? Неожиданное поведение платформы 170

Статья Системный администратор Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования Тестирование и исправление Разработка

Рассмотрим несколько случаев неожиданного поведения платформы 1С, а также что с этим можно cделать.

18.02.2019    13597    31    YPermitin    88       

Коннектор: удобный HTTP-клиент для 1С:Предприятие 8 559

Инструменты и обработки Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования Внешние источники данных WEB Универсальные функции Инструментарий разработчика Универсальные обработки

Коннектор - библиотека для работы с HTTP запросами. Библиотека берет на себя всю рутину работы с HTTP запросами. Буквально в одну строку можно получать данные, отправлять, не заботясь о необходимости конструирования URL, кодирования данных и т.п.

1 стартмани

31.01.2019    30634    273    bonv    116       

Программы для исполнения 488-ФЗ: Маркировка товаров Промо

1 января 2019 года вступил в силу ФЗ от 25.12.2018 № 488-ФЗ о единой информационной системе маркировки товаров с использованием контрольных (идентификационных) знаков, который позволяет проследить движение товара от производителя до конечного потребителя. Инфостарт предлагает подборку программ, связанных с применением 488-ФЗ и маркировкой товаров.

HTML в новой версии 8.3.14 на примере 3-х JavaScript библиотек: AmCharts, HighCharts, DHTMLX 172

Статья Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Универсальные обработки Практика программирования Разработка

Тестируем возможности HTML в новой версии 8.3.14 платформы на примере 3-х JavaScript библиотек: AmCharts, HighCharts, DHTMLX.

1 стартмани

29.01.2019    15530    66    Synoecium    37       

Отладка сложных отчетов на СКД 140

Отчеты и формы Программист Расширение (cfe) v8 v8::СКД 1cv8.cf Россия Абонемент ($m) Практика программирования

Расширение для отладки сложных отчетов на СКД (в т.ч. для собираемых программно "на лету") и быстрого перехода к отладке таких отчетов в консоли запросов и отчетов на СКД.

1 стартмани

28.12.2018    15452    61    maxx    56       

Очный семинар по регулярному менеджменту Александра Фридмана "Вы или Хаос", 12 декабря 2019 г. , Санкт-Петербург Промо

Семинар по регулярному менеджменту от Александра Фридмана для собственников, первых лиц и топов. Технология управленческого планирования, комплексного управления временем и другими ресурсами, выполнением поручений, делами, информацией, контактами (встречи-звонки-почта).

от 11000 до 29000 рублей

Реализация простого http-сервиса "Просмотр карточки номенклатуры(товара) в браузере" 144

Статья Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования

Практический пример реализации простого http-сервиса средствами 1С Предприятие 8.3. Обеспечивает просмотр списка товаров и просмотр данных товара в браузере.

1 стартмани

07.12.2018    14631    10    dmitry1975    31       

Использование подсистемы БСП "Заполнение объектов" 135

Статья Программист Расширение (cfe) v8 v8::УФ 1cv8.cf Россия Абонемент ($m) Практика программирования Универсальные функции БСП (Библиотека стандартных подсистем)

Применение механизмов БСП для добавления новых команд заполнения к формам различных объектов. Использование расширений конфигурации для доработки. Шаблоны для реализации собственных команд заполнения.

1 стартмани

23.11.2018    14875    8    ids79    22       

Онлайн-курс "Технология выполнения проектов ERP-класса – процессный подход". Третий поток. Курс проходит с 21 января по 18 марта 2020 года. Промо

Курс разработан Внедренческим центром «Раздолье». Курс предназначен для подготовки аналитиков, архитекторов и руководителей проектов автоматизации процессов управления с использованием комплексных ИТ-систем (1С:ERP, 1С:УХ, 1С:КА, 1С:УТ). В основе курса лежит методика применения процессного подхода.

9000 рублей

Работа с публикациями "Инфостарт" 14

Инструменты и обработки Программист Архив с данными v8 УУ Абонемент ($m) Практика программирования О сообществе WEB

Работа с рублевыми публикациями на сайте "Инфостарт": ведение клиентов, заказов, обновление файлов публикации, рассылка обновлений.

1 стартмани

13.09.2018    10518    10    RocKeR_13    16       

HTTP Сервисы: Путь к своему сервису. Часть 3 138

Инструменты и обработки Системный администратор Программист Расширение (cfe) v8 1cv8.cf Абонемент ($m) Инструментарий разработчика Практика программирования

Продолжение статьи «HTTP Сервисы: Путь к своему сервису. Часть 2». В предыдущих частях мы использовали только Get, в этой части поговорим о других методах и длительных операциях.

1 стартмани

27.08.2018    18019    32    dsdred    13       

Новый раздел на Инфостарте - Electronic Software Distribution Промо

Инфостарт напоминает: на нашем сайте можно купить не только ПО, связанное с 1С. В нашем арсенале – ESD-лицензии на ПО от ведущих вендоров: Microsoft, Kaspersky, ESET, Dr.Web, Аскон и другие.

  • Низкие цены, без скрытых платежей и наценок
  • Оперативная отгрузка
  • Возможность оплаты с личного счета (кешбек, обмен стартмани на рубли и т.п.)
  • Покупки идут в накопления для получения скидочных карт лояльности Silver (5%) и Gold (10%)

Позиционирование в помещении с помощью нейросети по сигналу Wi-Fi. Интерактивная карта склада в 1С с показом позиции 65

Инструменты и обработки Программист Бизнес-аналитик Приложение (apk) v8 Windows Абонемент ($m) Инструментарий разработчика Практика программирования

Данная публикация содержит в себе редактор и интерактивную карту склада или иного помещения, на которой в реальном времени отображается позиция устройства, координаты которого вычисляются по уровням сигнала нескольких роутеров Wi-Fi. В статье и приложенным к ней разработкам предлагаются инструменты и методика для реализации вычисления точной геопозиции внутри помещений с помощью нейронной сети. Конфигурация написана на релизе 1С:Предприятие 8.3.12.1412, клиентское приложение имеет минимальный уровень совместимости SDK -16.

5 стартмани

09.08.2018    16985    23    informa1555    26       

Работа с данными выбора 40

Инструменты и обработки Программист Архив с данными v8 Россия Абонемент ($m) Практика программирования Работа с интерфейсом

В управляемом интерфейсе заложена мощная возможность описывать связи реквизитов формы через параметры. Установка параметров связей позволяет ограничить выбор данных так, чтобы целостность данных была обеспечена на этапе ввода. Однако без дополнительного программирования задать можно только самые простые связи. Такие условия связи, как зависимость от реквизита через точку или зависимость через дополнительное отношение, заданное в регистре сведений - уже задать без программирования не получится.

1 стартмани

17.07.2018    23791    13    kalyaka    15       

Перенос данных КА 1.1 => ERP 2 (ЕРП) (обработка переноса документов, остатков и справочной информации из "1С:Комплексная автоматизация, ред. 1.1" в "1С:ERP Управление предприятием, ред 2"). Обновлен до КА 1.1.115.х и ERP 2.4.10.х Промо

Обработка позволяет переносить из КА 1.1 в ERP 2 документы за выбранный период и остатки. Типовая обработка от фирмы 1С документы не переносит. Также исправлены ошибки типовой обработки. При выходе новых релизов обновление высылается бесплатно в течение года. Разработка будет полезна фирмам-франчайзи, которые периодически выполняют такой перенос данных для заказчиков. Вы можете один раз приобрести обработку переноса, и потом бесплатно получать обновления в случае выхода новых релизов конфигураций 1С.

29700 руб.

HTTP Сервисы: Путь к своему сервису. Часть 1 287

Статья Системный администратор Программист Расширение (cfe) v8 1cv8.cf Абонемент ($m) Практика программирования WEB

Уже много было написано про http-сервисы, но то и дело всплывают «Новые» статьи по обмену между базами V8 по COM, что «Немножко» удивляет. Решил внести свои 5 копеек, поработаем с http-сервисом.

1 стартмани

15.07.2018    42208    17    dsdred    22       

ВСТАВИТЬ В Справочник.Номенклатура (Код, Наименование) ЗНАЧЕНИЯ ("001", "Новый товар") 105

Инструменты и обработки Программист Внешняя обработка (ert,epf) v8 v8::Запросы 1cv8.cf Абонемент ($m) Практика программирования

Вас не обманывают ваши глаза, это запрос на изменение данных! И это работает без прямого доступа к БД, регистрации и смс.

1 стартмани

01.06.2018    20807    86    m-rv    57       

Перенос данных БП 2.0 => УТ 11 / КА 2 / ERP 2 (перенос остатков, документов и справочников из "1С:Бухгалтерия предприятия 8", ред. 2.0 в "1С:Управление торговлей 8", ред.11 / КА 2 / ERP 2). Обновлено до УТ 11.4.10.х, КА 2.4.10.х, ERP 2.4.10.х! Промо

Перенос позволяет загрузить в УТ 11 / КА 2 / ERP 2 документы за выбранный период, справочную информацию и остатки по счетам бух. учета. Переносятся остатки денежных средств, взаиморасчетов, остатки товаров и материалов на складах. Переносятся девятнадцать основных видов документов за выбранный период и вся нормативно-справочная информация. Есть фильтр по организации. Если нужно переносить что-то дополнительно, то обычно бесплатно дорабатываю правила (перед покупкой согласуйте необходимые доработки).

29700 руб.

БСП: Дополнительная обработка (Регламенты), примеры от простого к сложному 241

Статья Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Практика программирования БСП (Библиотека стандартных подсистем)

Очень много попадается странных решений, которые можно решить через БСП:Дополнительные отчеты и обработки. Я бы вообще БСП из-за этой подсистемы переименовал в «Большое Спасибо Программистам». Поработаем с подсистемой в части написания регламентных заданий.

1 стартмани

10.05.2018    29093    28    dsdred    34       

1С:Предприятие через Интернет. 1С:Fresh Промо

Ведение бухгалтерского и налогового учет, сдача отчетности, управление бизнесом из любой точки мира. Привычные программы «1С» через Интернет без приобретения коробочных программ.

Как выполнить отчет на СКД через COM и получить данные отчета? 86

Статья Программист Архив с данными v8 УПП1 Россия Windows Абонемент ($m) Практика программирования

Для чего это нужно. Например, нужно в одной базе получить какой-либо показатель из другой базы. Этот показатель вычисляется в каком-либо сложном отчете, который написан на СКД. Можно, конечно, "скопипастить" текст запроса из другой базы, немного подправить его и выполнять в том же COM подключении. Но с этим теряется гибкость: если отчет изменился, то нужно помнить о том, что где-то есть его "немного модифицированная" копия. В статье будет рассмотрен пример получения данных из базы ЗУП.

2 стартмани

08.05.2018    18909    10    wowik    3       

Работа со схемой запроса 176

Статья Программист Конфигурация (md, cf) v8 v8::Запросы Абонемент ($m) Инструментарий разработчика Практика программирования

Стандартом взаимодействия с реляционной базой данных стал язык SQL. Приемником SQL в 1С является язык запросов. Язык запросов, также как и SQL, является структурированным. Составляющие структуры запроса отвечают на разные вопросы о том, какие данные требуется получить и какие манипуляции с множествами данных необходимо произвести при получении. В простых случаях текст запроса можно написать вручную, однако в сложных случаях, а также при программном формировании, - лучше воспользоваться объектной моделью запроса и использовать объект "Схема запроса". В статье дается описание объектной модели и особенностей работы с ней, а также приводится решение, упрощающее взаимодействие с объектом "Схема запроса".

1 стартмани

24.04.2018    30033    75    kalyaka    34       

Перенос документов, остатков и справочников КА 1.1 => КА 2 / УТ 11. Обновлено до КА 2.4.10.х и УТ 11.4.10.х! Промо

Более 130 компаний выполнили переход на КА 2 или УТ 11 с помощью нашей разработки! Позволяет перенести не только остатки и справочники (как типовая обработка), но и документы за нужный период времени. Предоставляем техподдержку, оперативно исправляем замечания, выпускаем обновления при выходе новых релизов программ 1С. Вы можете проверить разработку до покупки: сделаем бесплатный тестовый перенос из вашей базы КА 1.1 и предоставим доступ к базе-результату через веб-клиент!

29700 руб.

Асинхронная запись и чтение файла без использования модальных методов и временных файлов 134

Статья Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Практика программирования

В статье рассмотрено решение задачи формирования и записи файла на основе данных информационной базы. Формирование происходит на стороне сервера с помощью механизма потоков. Используются асинхронные методы передачи файлов между клиентом и сервером. Также рассмотрено решение обратной задачи - чтение файла и запись его данных в информационную базу. Статья ориентирована прежде всего на новичков, также приведенный код может использоваться в качестве шаблона.

1 стартмани

10.04.2018    19884    18    Alxby    23       

Заполняем по шаблону (по умолчанию) 69

Инструменты и обработки Программист Архив с данными v8 v8::УФ 1cv8.cf Абонемент ($m) Практика программирования

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

1 стартмани

08.02.2018    18665    20    mvxyz    17       

Перенос данных КА 1.1 / УПП 1.3 => БП 3.0 (перенос остатков, документов и справочников из "1С:Комплексная автоматизация 1.1" / УПП 1.3 в "1С:Бухгалтерия 3.0"). Обновлен до версий КА 1.1.115.х, УПП 1.3.127.х! Промо

Разработка позволяет перенести остатки по всем счетам бух.учета в программу "1С:Бухгалтерия предприятия 8", ред. 3.0 на выбранную дату начала ведения учета. Также переносятся документы за период и вся необходимая справочная информация. Правила оперативно обновляю при выходе новых релизов. Рассылка обновлений правил бесплатно в течение 12 месяцев. Есть видеодемонстрация проведения переноса данных. Конфигурации при использовании обмена остаются полностью типовыми. Перенос данных возможен в Бухгалтерию 3.0 версии ПРОФ, КОРП или базовую.

24700 руб.

Бесплатная проверка контрагентов в ФНС (общий модуль с алгоритмом). На примере выводим статус в список справочника контрагентов 124

Статья Программист Конфигурация (md, cf) v8 1cv8.cf Абонемент ($m) Практика программирования

Если вам интересно проверить контрагенте в ФНС, вам поможет данная публикация. Весь алгоритм работы строится на основе данных, полученных с сервиса http://npchk.nalog.ru совершенно бесплатно.

1 стартмани

01.02.2018    26395    62    rpgshnik    46       

Расширение возможностей печати: Вывод произвольного нижнего и верхнего колонтитула 8

Отчеты и формы Программист Внешняя обработка (ert,epf) v8 1cv8.cf Абонемент ($m) Печатные формы документов Практика программирования Универсальные функции

Расширяем функционал вывода нижнего / верхнего колонтитула. Стандартно 1С имеет достаточно ограничений по выводу и наполнению колонтитулов содержимым, взять хотя бы такие, как вывод только текста и отсутствие ограничения на номер конечной страницы. А при разработке кода сталкиваешься с тем, что свой блок с нижним колонтитулом нужно прижимать к низу страницы. Казалось бы быстро решаемый вопрос, но и в нем есть нюансы. Сейчас я расскажу о том, как решалась эта задача. UPD 15.02.2018. Добавлен вывод верхнего колонтитула; Вывод колонтитулов на первой и последней странице управляется параметрами; Научился считать страницы: Добавлено заполнение переменных аналогичных стандартным из колонтитулов; Задаются форматы даты и времени. Ограничения прежние: 1. Повторно сформировать табличный документ после смены параметров страницы интерактивно.; 2. Передавать данные для более плотной печати как можно более мелко нарезанными кусками.

1 стартмани

29.12.2017    24496    21    agent00mouse    0