Универсальная структура подчиненности документов

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

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

Отчет "Универсальная структура подчиненности документов" позволяет увидеть иерархию документов (с возможностью использования произвольных отборов и вывода произвольных полей). Реализовано для обоих режимов запуска (обычная и управляемая формы).

Вашему вниманию предлагается отчет для анализа документов с точки зрения подчиненности одного документа другому. Ну, "для анализа" - это, наверное, громко сказано... Но "чисто поглазеть" точно можно Smile.

В верхней части отчета расположены различные настройки, а в нижней - само дерево документов.

Пробежимся по настройкам:

  1. Страница "Корневой документ" - в поле "Типы корневого документа" выбираются типы корневого документа. Возможно выбрать больше одного типа (и даже все - контекстное меню к полю), но это скажется соответствующим образом на производительности. Под полем выбора корневых документов расположено дерево отборов (СКД). Как работать с отбором СКД, подозреваю, рассказывать не надо...
  2. Страница "Отборы"- так называемые "произвольные отборы", позволяющие накладывать условия на любые уровни документов. Знание языка запросов приветствуется (но для простых условий отбора - необязательно). Для обращения к документам различных поколений введены вспомогательные конструкции:
    1. [Документ5] - представляет собой документ пятого поколения (вместо пятерки используйте нужное поколение)
    2. [ДокументX] - подразумевает под собой документ каждого уровня, т.е. отбор с данной конструкцией будет использоваться в каждом поколении
    3. [ДокументA] и [ДокументB] - два соседних документа

    Первую конструкцию я бы назвал статической, а остальные - динамическими. Под конструкциями следует понимать ссылки на документы. Реквизиты "вытаскиваются", через точку: НачалоПериода([ДокументX].Дата, ДЕНЬ) = ДатаВремя(2011, 1, 1). Запрещено использование различных конструкций в одном условии. Также есть аналогичные конструкции, но вместо слова "Документ" используется слово "Состояние" ([СостояниеX] и т.д.) - это число, где 0 - документ помечен на удаление, 1 - не проведен, 2 - проведен. Извиняюсь за англ. раскладку Embarassed 

    У каждого условия есть три флажка:

    1. Использование - Включение/выключение отбора 2. ИЛИ - если флажок установлен, то условие будет работать по принципу "хотя бы один" (если условие выполнится для ветки хотя бы один раз); если флажка нет, то подразумевается условие "все" (как бы "И"). Условия ИЛИ накладываются на самой последней стадии, в связи с чем, слабо сказываются на увеличении скорости работы. Несколько условий ИЛИ объединяются по принципу "ИЛИ", остальные - по принципу "И". Laughing 3. Обязательное - если флажок установлен, то отбор обязательно отработает; если не установлен - то отбор не будет применяться для веток, у которых количество поколений меньше максимального номера поколения в условии. К примеру: [Документ3].Проведен с установленным флажком отберет все ветки в которых документ в третьем поколении проведен, а без флажка - будут отобраны еще и ветки, состоящие только из двух (или одного) документов.

  3. Страница "Поля" - в поле "Выражение" указывается путь к реквизитам (в общем говоря, выражение на языке запросов). До реквизитов добираемся с помощью слова Документ. К примеру: Документ.Дата. Ну, или другой пример: ЕСТЬNULL(Документ.Склад, "NULL").
  4. Страница "Параметры" - если на страницах "Отборы" и/или "Поля" использовались какие-то параметры (те, что с символом &), то здесь их следует прописать, и указать значение.
  5. Страница "Настройки" - здесь собраны некоторые общие настройки:
    1. Типы детей - назначение, думаю, понятно из названия... Один из наиболее эффективных способов ускорить работу отчета, это указать в этом поле как можно меньше документов Smile. В контекстном меню к полю есть пункт "Выбрать все".
    2. Расширительные типы - самый туманный параметр... Нужен ли он вообще - точно не знаю. В общем, когда-нибудь, наверное, может сложиться ситуация, что в отборе или в полях мы обратились к какому-то реквизиту, который есть только у, скажем, одного документа, и если по каким-то причинам в каком-то поколении этого документа не оказалось (т.е. даже не было связи с этой таблицей), то возникнет ошибка. Если вы считаете, что все прописали правильно, то, может быть, имеет смысл добавить сюда этот тип документа. Но думаю, потребности его трогать у вас не возникнет...
    3. Мин. количество поколений - ветки короче указанного числа отображаться не будут
    4. Макс. количество поколений - после достижения указанного количества поколений анализ документов заканчивается. Если включить этот параметр со значением один, то, понятное дело, никакого дерева мы не получим (фактически получится простой список), но зато отчет выполнится довольно быстро Wink

Как использовать отчет придумывайте сами. Можно, к примеру, просто вывести список всех документов одного ответственного. Или отобрать те документы где различаются склады у документа-родителя и документа-ребенка... Или еще чего-нибудь...

Теперь немного о грустном: на демо-базах работает на ура. А вот на реальных, тяжелых базах... На реальных базах работает со скрипом. Выбрав в качестве корневого документа один тип документа, установив некоторый отбор по дате, в третьем поколении я получаю соединение с ~140 таблицами и не дождавшись отклика убил одинэску через энное количество часов... В общем, если отчет используется для дела, то рекомендую в каждом конкретном случае указывать какие типы детей-документов вас интересуют и сохранять настройки.

Ошибку с 256 таблицами в запросе пока никак не обрабатывал. (честно говоря, даже не знаю, на сколько это сейчас актуально - я на нее ни разу не попал)

Некоторые интерфейсные части отчета можно было бы сделать и поудобнее, но в связи с наличием двух одинаковых форм, это не самое интересное занятие...

На управляемых формах до этого практически не писал, так что один-другой лишний байтик-мегабайтик может побегать по проводам ;)

На платформах младше 8.2.11.235 даже не запускал. 

Буду рад дельным советам и конструктивной критике Wink 

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

Наименование Файл Версия Размер
Универсальная структура подчиненности документов

.erf 41,52Kb
410
.erf 41,52Kb 410 Скачать

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

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. kapustinag 27.11.11 22:50 Сейчас в теме
Если в третьем поколении получаете соединение с 140 таблицами, то в третьем же или в четвертом поколении можете легко выйти на >256 таблиц - если в базе (скажем, УПП) включен контроль доступа на уровне записей. И тем более можете выйти на это ограничение, если в конфигурации объединено несколько подсистем разного назначения. Например, УПП+УАТ+ТОИР. Поэтому имеет смысл позаботиться об этом.
Также из опыта могу предложить еще одно направление развития этого отчета: должна быть возможность получить структуру подчиненности не только вниз (от корня к детям), но в обе стороны.
pvlunegov; +1 Ответить
5. Koog 38 28.11.11 21:10 Сейчас в теме
(1) Да, я не отрицаю, что позаботиться о "256 таблицах" надо. Но на моих целевых базах (не файловых :)) данный момент пока не проявлялся. Да и в любом случае, в первую очередь я отдал бы предпочтение доработке запроса по поиску документов-детей (с целью ускорения его работы). Но сейчас со временем напряг...
По поводу получения предков корневых документов - такая идея у меня тоже была, но я не смог представить как будет выглядеть это дерево :))) Поможете? ;) Была придумка добавлять к корневому документу ветку с каким-нибудь названием типа "Родители" в которой бы и находилась иерархия родителей (от наиболее близких родственников до самых старых)... Но пока решил это не реализовывать...
2. Angeros 28.11.11 05:47 Сейчас в теме
Отчет классный, но не хватает версии для 8.1
3. ingrid2011 28.11.11 12:45 Сейчас в теме
(2) Angeros, Прошу прощения, но почему вы еще на 8.1 сидите?
4. Angeros 28.11.11 13:46 Сейчас в теме
(3)Стабильность 8.2 только недавно на мой взгляд сравнилась с 8.1, сейчас готовлюсь к переходу...
6. Koog 38 28.11.11 21:18 Сейчас в теме
(2) До публикации отчета я пробывал его запускать в 8.1. хе-хе-хе Пробывал конвертить в конфигураторе 8.1. хе-хе-хе Данная фича анэвэйлэбл. :) Честно говоря, я уже не скажу использовались ли какие-то фишки 8.2, которых не было в 8.1 (говорю про код модуля объекта - где основная логика и расположена), но, думаю, в любом случае, переделать отчет на 8.1 не составит труда. Но, видимо, лучше все-таки переходить на 8.2... (не из-за отчета ессно, а вообще)
7. Angeros 29.11.11 04:55 Сейчас в теме
(6)Ну согласен. 8.2 лучше 8.1 рано или поздно все перейдут
8. Vond 05.12.11 01:56 Сейчас в теме
Интересное решение, красиво, наглядно, гибко на первый взгляд. Будем изучать плотнее :)
9. Koog 38 05.12.11 21:16 Сейчас в теме
10. Гость 06.12.11 06:31
Уже сижу! очень интересна и гибка в настройке!
11. adhocprog 1197 11.01.12 14:37 Сейчас в теме
12. mtsdc 19.03.12 08:00 Сейчас в теме
13. Lyuba-Lyuba 03.04.12 14:21 Сейчас в теме
15. luchyk007 14.05.13 14:09 Сейчас в теме
а вообще в управляемой форме документа можно через стандартный механизм 1с-ки получить структуру подчинённости документов и как это сделать
16. TMV 14 14.05.13 17:57 Сейчас в теме
[QUOTE= "фыв"]и как это сделать [/IS-QUOTE] это вопрос?
17. m13 27.09.13 12:42 Сейчас в теме
При формировании под полными правами работает номально. Если полных прав нет, то выдает ошибку:

{Отчет.УниверсальнаяСтруктураПодчиненностиДокументов.МодульОбъекта(181)}: Ошибка при визове метода контекста (Выполнить)
СуперЗапрос.Выполнить();
через:
{(2, 28)}: Поле не найдено "ТаблицаКорневогоДокумента.Ссылка"
ТаблицаКорневогоДокумента.<<?>>Ссылка КАК Документ1

1С 8.2.18.109, УПП обычное приложение.
19. InWith 25 19.12.13 01:41 Сейчас в теме
(17)тоже самое под полными правами в УТ 11.1
18. МилаяКсюшка 09.12.13 09:30 Сейчас в теме
Можно избежать ошибку, подправив запрос ВЫБРАТЬ РАЗРЕШЕННЫЕ
20. Koog 38 20.12.13 20:54 Сейчас в теме
(18) Вообще, это было первое что я попробовал, но ошибка осталась. К сожалению, сейчас немного не хватает времени. Постараюсь на новогодних разобраться...
21. Ddkoshka 13.01.14 19:01 Сейчас в теме
Спасибо Вам большое за эту обработку! Вы сильно облегчили жизнь и работу!
22. galaktika@tut.by 15.06.14 16:56 Сейчас в теме
Спасибо! Нет слов,класс!
23. mir9001 23.01.15 08:50 Сейчас в теме
Отличная обработка, но как мне сделать отбор чтобы показывалось дерево вверх? Скажем мне надо проверить по всем ли реализациям были выписаны счета и заказы.
24. Викунец 19.02.16 18:59 Сейчас в теме
25. German_Tagil 27 12.10.16 08:37 Сейчас в теме
26. German_Tagil 27 12.10.16 09:33 Сейчас в теме
вопрос - а привязать вложенную Таблицу Товары каким то образом можно?
Или может кто видел подобную реализацию - буду признателен
27. noor 12 11.12.16 14:01 Сейчас в теме
Круть крутейшая. То что надо.
28. German_Tagil 27 14.12.16 07:19 Сейчас в теме
(0) Алексей (Koog) Мне не понравилось что структура дерева повторяется
да итоги бы не помешали
посмотрите рисунок
Прикрепленные файлы:
29. Tanis 13.04.17 19:24 Сейчас в теме
Спасибо!
Очень выручила в срочности решения.
30. user686745 09.08.17 10:24 Сейчас в теме
Добрый день , подскажите с чем может быть связана данная ошибка , на тестовой базе все отлично работает
Прикрепленные файлы:
31. asp-1c 29.05.18 11:11 Сейчас в теме
Добрый день, как вывести в отчете сумму документа-и родительского, и подчиненных?
Оставьте свое сообщение

См. также

FormCodeGenerator Программная доработка форм. Часть 2 (Режим работы "Режим сравнения форм") на примере ERP 2.5 Промо

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

Данная публикация является продолжением описания функционирования обработки "FormCodeGenerator " в режиме сравнения форм и генерирования кода на основании сравнения. Подходит для перевода уже доработанных форм с интерактивной доработки на программную. Данный режим работы обработки снизит издержки при дальнейших обновлениях конфигураций.

5 стартмани

21.12.2020    4071    19    huxuxuya    11    

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

Работа с интерфейсом v8 ERP2 УТ11 Россия Абонемент ($m)

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

1 стартмани

09.09.2019    13929    27    bmk74    6    

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

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

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

1 стартмани

03.07.2019    23737    6    m-rv    90    

Открывашка ячеек таблиц

Работа с интерфейсом v8 1cv8.cf Абонемент ($m)

Глобальное сочетание клавиш для открытия объекта по ссылке из текущей ячейки любой таблицы в большинстве управляемых форм

1 стартмани

27.10.2018    19284    12    tormozit    31    

Расширенная настройка динамического списка УФ Промо

Работа с интерфейсом v8 v8::УФ 1cv8.cf Абонемент ($m)

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

1 стартмани

31.05.2017    35359    159    tormozit    25    

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

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

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

1 стартмани

13.09.2018    24438    13    RocKeR_13    16    

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

Инструментарий разработчика Практика программирования v8 Абонемент ($m)

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

5 стартмани

09.08.2018    31452    28    informa1555    26    

Визуализация событий на временной шкале средствами "Поле HTML документа"

Работа с интерфейсом v8 1cv8.cf Абонемент ($m)

Интересный способ наглядно отобразить события на временной шкале. Например, может быть применен для красивого вывода документов по клиенту. Тестировалось на платформе 8.3.12.1469

1 стартмани

31.07.2018    26002    141    Plotks2017    27    

Лучший подарок для бухгалтера - счёты 8.2 (со звуком) Промо

Работа с интерфейсом v8 1cv8.cf Россия Абонемент ($m)

(Толстый клиент) Подарите бухгалтеру счеты, и он(а) Вас никогда не забудет.

1 стартмани

13.05.2011    42336    922    Tatitutu    45    

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

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

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

1 стартмани

17.07.2018    56735    21    kalyaka    16    

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

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

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

1 стартмани

01.06.2018    32957    88    m-rv    58    

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

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

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

1 стартмани

08.02.2018    30973    20    mvxyz    17    

Нечеткий поиск одним запросом Промо

Практика программирования v8 1cv8.cf Абонемент ($m)

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

1 стартмани

28.12.2015    30593    72    vasvl123    9    

Печатная форма, сделанная как расширение конфигурации для БП 3.0. Новые возможности БСП

Практика программирования Универсальные печатные формы v8 БП3.0 Абонемент ($m)

Печатные формы на внешних обработках скоро канут в лету. На смену им приходят ПФ, реализованные в виде расширений конфигурации. Не нашел на сайте примеров таких расширений. Привожу пример подобного расширения для БП 3.0.

1 стартмани

06.12.2017    29477    56    kwazi    6    

Программное формирование форматированной строки в стиле html+inline CSS

Работа с интерфейсом Инструментарий разработчика v8 1cv8.cf Абонемент ($m)

Если вам приходилось работать с форматированными строками программно, то вы знаете, какая это боль. Данное решение облегчает программное формирование таких строк.

1 стартмани

18.11.2017    36691    42    bonv    11    

Расширения конфигураций 1С: учимся перехватывать методы

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

В этой статье я на примерах разберу некоторые механизмы расширений конфигураций 1С. А именно «перехваты» методов модуля объекта и «перехваты» событий формы и элементов формы. Данная статья написана с учебными целями, чтобы показать, как при помощи расширений конфигурации можно делать такие доработки, ради которых раньше приходилось снимать конфигурацию с поддержки.

1 стартмани

30.05.2017    148037    13    signum2009    48    

1С: Предприятие + корпоративный чат, как наладить оперативные уведомления за 10 минут

Практика программирования v8 Абонемент ($m)

Как сделать автоматические уведомления о разных событиях из 1С в корпоративный чат MyChat для сотрудников компании

1 стартмани

14.08.2016    51034    36    Demanoidos    60    

Хранение файлов в томах на диске (для УПП 1.3)

Практика программирования v8 УПП1 Абонемент ($m)

Доработка типовой УПП 1.3 в плане хранения присоединенных файлов вне базы данных

2 стартмани

05.06.2016    61986    11    wowik    32    

БСП 2.3 и БСП 3.0: Просто про выполнение внешней обработки в фоне (c индикацией прогресса выполнения)

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

Простое пояснение о том, как сделать внешнюю обработку с фоновым выполнением и индикацией процесса для любой конфигурации на основе БСП 2.3.2. UPDATE 20/09/19: добавлен вариант обработки с индикацией процента выполнения и статусом выполнения для БСП 3.0.

1 стартмани

18.05.2016    67652    199    rozer    66    

Остатки на каждый день в запросе

Практика программирования Учет ТМЦ Учет ТМЦ v8 1cv8.cf УУ Абонемент ($m)

Запрос формирует остатки товаров на каждый день в пределах выбранного периода.

1 стартмани

26.04.2016    67145    19    arakelyan    22    

Выполнение JavaScript кода из 1С в объекте Поле HTML Документа (HTML 5) и вызов события в 1С ПриНажатии

Практика программирования v8 1cv8.cf Россия Абонемент ($m)

Пример выполнения JS кода из 1С в Поле HTML Документа под управляемыми формами, с удобным получением результата в 1С(С помощью вызова привязанного события ПриНажатии к элементу ПолеHTMLДокумента)

1 стартмани

22.03.2016    87800    165    igo1    54    

Количество дней недели (понедельников/вторников/...) в заданном диапазоне одним запросом

Практика программирования v8 Абонемент ($m)

При реализации периодического авто-заполнения маршрутных листов по графику (недельному) необходимо было просчитать стоимость всего периода, с условием выездов только по определенным дням. Заморачиваться с обходом результата не хотелось. Пришлось написать "Небольшой" запрос.

1 стартмани

03.03.2016    20290    1    Alexander.Shvets    5    

Простые радости жизни программиста 1С: выбор типа значения

Работа с интерфейсом Практика программирования v8 1cv8.cf Абонемент ($m)

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

1 стартмани

17.02.2016    54139    54    yuraos    18    

Отображение прогресса выполнения длительных операций в БСП и их отладка в текущем сеансе.

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

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

1 стартмани

17.02.2016    61526    201    balanton    23    

Яндекс.Деньги "Благотворительность"

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

Яндекс.Деньги теперь в 1С. Форма для приема благотворительных взносов. Форму легко сделать и вставить на любую страницу сайта или блога. Платежи будут приходить на ваш кошелек. На форме есть три способа платежа: из кошелька, с банковской карты, с баланса мобильного.

1 стартмани

16.02.2016    25356    8    Tatitutu    5    

Мастер рассылки e-mail 2.2 для управляемых форм

Практика программирования Email v8 v8::УФ ERP2 БП3.0 УТ11 Абонемент ($m)

Для пользователей: переделанный из старый разработки под 8.2 с использованием библиотеки Мастер рассылки e-mail 2.2 (ERP, УТ, БП) (Только управляемые формы), который теперь может запускаться под любой версией платформы с разрешенными или запрещенными модальными/синхронными вызовами в конфигурации. Также удобный выбор e-mail и их владельцев с помощью отбора динамического списка по любым критериям и галочки исключения.

1 стартмани

29.12.2015    42440    20    milkers    4    

Передача больших пакетов через веб-сервисы

Практика программирования Администрирование данных 1С Внешние источники данных v8 Абонемент ($m)

Реализация механизма передачи больших пакетов через веб-сервисы. С его помощью передать файл размером в несколько гигабайт не составит проблем.

1 стартмани

06.12.2015    60834    51    YPermitin    19    

Пример связи 1С и мессенджера Telegram. Получение данных из 1С запросом из Telegram

Практика программирования Внешние источники данных v8 1cv8.cf Абонемент ($m)

В результате чтения публикации Вы получите готовую внешнюю обработку, позволяющую получать из 1С данные, запрашиваемые через Telegram. В данной статье рассмотрим следующее: Использование HTTPСоединение; Чтение JSON для версии 1С 8.3.6 и выше, а также аналог JSON для версии 1С ниже 8.3.6; Подключение обработчика ожидания; Некоторые основные возможности API Telegram; Как создать бота для Telegram; Программное создание колонок дерева на управляемой форме;

1 стартмани

19.11.2015    102912    484    Luchik    210    

Быстрое определение интервалов в запросе

Практика программирования v8 Абонемент ($m)

В статье описывается новый метод определения интервалов между данными различных записей в запросе. В отличие от общеизвестного метода, время работы предлагаемого метода зависит от объема данных ЛИНЕЙНО. Это обеспечивает ему значительный выигрыш по быстродействию на больших объемах данных. В качестве иллюстрации возможностей метода приведен отчет, показывающий гистограмму распределения времени между продажами.

1 стартмани

01.10.2015    55751    35    ildarovich    41    

Полезные приемы при работе с Excel из 1С (Версия 3.1)

Практика программирования Разработка внешних компонент Загрузка и выгрузка в Excel v8 1cv8.cf Абонемент ($m)

Программисту 1С часто приходится работать с таблицами Excel из 1С. Я постарался собрать небольшой FAQ и набор функций для работы с файлами Excel. Надеюсь, кому-то будет полезна данная статья.

1 стартмани

22.09.2015    224298    477    Zerocl    76    

Javascript и 1С. Кросс-платформенное взаимодействие

Практика программирования v8 1cv8.cf Абонемент ($m)

Что делать, если необходим богатый интерфейс, а управляемые формы нам его не могут обеспечить? Использовать HTML и JavaScript. В статье рассмотрено взаимодействие кода 1С и JavaScript, работающее на любой платформе: толстый, тонкий и веб-клиент, под Windows и Linux.

1 стартмани

14.09.2015    74106    210    VitaliyCeban    59    

Code First и Linq to EF на примере 1С версии 7.7 и 8.3 часть I

Практика программирования v8 Абонемент ($m)

Данный проект является чисто исследовательским примером использования Code First и Linq to EF на примере 1С версии 7.7. Так как сам я программист 1С, то мне всегда было интересно, как можно перенести модель объектов 1С на компилируемые языки, и использовать мощь Linq to EF. С появлением Code First давно хотел прикрутить, но все как-то руки не доходили, и вот, наконец ..

1 стартмани

28.08.2015    24271    3    Serginio    2    

Универсальная учетная система с конструктором документов и справочников в режиме 1С: Предприятие

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

Заголовок статьи звучит фантастично, но это не шутка. Занимаясь внедрениями, я часто сталкивался с ситуацией, когда надо было к типовой конфе приделать простенький модуль учета чего-нибудь, не специфичного для самой конфы. Например в УТ учет материалов в эксплуатации. Модуль обычно состоял из пары справочников (2-3), 3-х документов и регистра или пары регистров. Однажды подобные пристройки понадобились одновременно на 3 проектах. Скучно делать одинаковую работу, и я подумал, а что, если сделать универсальный инструмент, в котором пользователь сам сможет нарисовать себе справочники, реквизиты к ним, документы и движения. Т.е. конструктор полноценных документов в пользовательском режиме. Это оказалось не так сложно - все дело в подходящей архитектуре данных.

1 стартмани

29.07.2015    33331    142    informa1555    41    

NativeDraw: Компонента рисования для 1С [V2.6.2]

Разработка внешних компонент Работа с интерфейсом v8 1cv8.cf Абонемент ($m)

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

1 стартмани

13.07.2015    49872    466    ПерваяСистема    147    

Методы для группировки данных по полю,полям в Таблице Значений на примере универсального метода списания по партиям, а также отбора строк в ТЗ по произвольному условию. Для 8.x и 7.7

Универсальные функции Практика программирования v7.7 v8 1cv8.cf 1cv7.md Абонемент ($m)

Я очень часто использую группировку данных по полю и полям, как в восьмерке, так и в семерке. Это аналог запроса Итоги, но там строится дерево, а в большинстве случаев нужны "плоские данные". Да и делать запрос в большинстве случаев более накладный процесс, чем работа с ТЗ. Все достоинства такого подхода приведены на примере метода универсального списания по париям, а так же отбора строк в ТЗ по произвольному условию. Для 7.7 еще отчеты сравнения двух ТЗ. Работая с различными базами для упрощения сравнения номенклатуры, или как аналог джойнов(join), сделал сравнение двух таблиц значений по нескольким полям. Пока группировки полей должны быть уникальны. Часто приходится искать дубли, для универсального поиска есть ДублиВТзПоПолю и пример в Тест.ert.

1 стартмани

25.06.2015    29882    4    Serginio    1    

И снова "Как сжать картинки для экспорта в EXCEL?" или Умная картинка 8.2

Практика программирования Загрузка и выгрузка в Excel v8 1cv8.cf Абонемент ($m)

Прошла уже эпоха , когда экономили на трафике интернета. Но все же...повторюсь. Я предлагаю совершенно новый способ сжатия картинки - эффект в 20 раз !!!

1 стартмани

17.06.2015    32477    54    Tatitutu    10    

Кнопки управления группировками табличного документа для управляемых форм

Работа с интерфейсом v8 1cv8.cf Абонемент ($m)

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

1 стартмани

02.06.2015    27969    29    unichkin    9    

Альтернативная визуализация данных для 1С 8.3.6

Работа с интерфейсом v8 1cv8.cf Абонемент ($m)

Нужен приятный Bi Dashboard? Или просто красивый график/диаграмма для сайта? Тогда эта разработка для Вас!

1 стартмани

29.05.2015    32807    80    vano-ekt    3    

Регулярные выражения без COM объектов и внешних компонент

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

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

1 стартмани

09.02.2015    26331    19    boogie    38    

Асинхронные вызовы

Практика программирования v8 1cv8.cf Абонемент ($m)

В этой статье я покажу свою реализацию асинхронных вызовов серверных функций и процедур

1 стартмани

02.02.2015    45939    163    rtnm    25    

Разбор XML документа - почти все возможные способы

Обмен через XML Практика программирования v8 1cv8.cf Абонемент ($m)

К вам пришел XML документ, как получить из него данные для обработки в 1С. ЧтениеXML, ДокументDOM, XPath, ФабрикаXDTO, ПакетыXDTO в сравнении.

1 стартмани

05.11.2014    254987    740    svenderevsky    99