Распределение расходов пропорционально продажам

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

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

финансовая модель учет расходов

Финансовая модель. Распределение административных расходов по подразделениям пропорционально продажам за месяц. Дополнительные реквизиты против бизнес-процессов!

Дополнительные реквизиты против бизнес-процессов!

Для кого: для финансового директора - для понимания, что не Excel'ем единым жив финансовый учет.

Для кого: для программиста - для понимания, как внедрить предлагаемую финансовую модель.

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

Подобная финансовая модель не реализована типовым функционалом в УТ 10.3, поэтому потребовалась доработка УТ 10.3. Как и любая модель имеет свои допущения и ограничения. Внедрялась на конкретном предприятии с конкретными бизнес-процессами, и поэтому не претендует на универсальность.

Самое скучное

- разобрать структуру решения на уровне таблиц

Шаг 1. Представьте 4 розничных магазина и 1 бэк-офис администрации. Магазины учитываются как подразделения организации (справочник "Подразделения") (см. рисунок).

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

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

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

Шаг 3. В соответствующих документах "ПлатежноеПоручениеИсходящее", "ПлатежныйОрдерСписаниеДенежныхСредств", "РасходныйКассовыйОрдер" - к имеющемуся типовому полю "Подразделение" была добавлена табличная часть "РаспределениеРасходовПоПодразделениям" с единственным полем "Подразделение" (см. рисунок).

Модель строится на следующем принципе:

- если расход денежных средств относится на конкретное подразделение, то соответствующее подразделение указывается только в типовом поле документа "Подразделение",

- если расход ДС необходимо распределить, то в типовом поле "Подразделение" необходимо выбрать подразделение "Администрация", а в табличной части "РаспределениеРасходовПоПодразделениям" указать все подразделения. Предполагается, что расходы относятся или только к одному подразделению, или сразу ко всем.

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

Самое сложное

- понять типовые алгоритмы и куда внести изменения с минимальными "потерями"

Шаг 4. В модуле объекта каждого документа проведение доработано следующим образом - в процедуру общего модуля передается массив подразделений:

Процедура ДвиженияПоРегистрамУпр(Режим, Отказ, Заголовок, СтруктураШапкиДокумента)

    ...
      
    УправлениеДенежнымиСредствами.ПровестиСписаниеДенежныхСредствУпр(
       
СтруктураШапкиДокумента, мСтруктураПараметровДенежныхСредств, ТаблицаПлатежейУпр,
       
Движения, Отказ, Заголовок, РаспределениеРасходовПоПодразделениям.ВыгрузитьКолонку("Подразделение")); //доработка+

КонецПроцедуры // ДвиженияПоРегистрамУпр()

 

В соответствующей процедуре общего модуля были внесены следующие правки:

Если Оплачено И (ОтраженоВОперУчете ИЛИ ПоРасчетномуДокументу) Тогда 

        // Проводим по фактическим взаиморасчетам

        // По регистру "Движения денежных средств"

       
ТаблицаДвиженияДенежныхСредств = Движения.ДвиженияДенежныхСредств.ВыгрузитьКолонки();

        ... // здесь код не менялся

        // Недостающие поля.
       
ТаблицаДвиженияДенежныхСредств.ЗаполнитьЗначения(ВидДенежныхСредств, "ВидДенежныхСредств");      

        ... // здесь код не менялся

        //доработка+ начало
       
Если МассивПодразделений <> Неопределено И МассивПодразделений.Количество()>0 Тогда

           
СоответствиеТаблиц = Новый Соответствие;
            Для
кол = 1 По МассивПодразделений.Количество() Цикл

                Если
кол = 1 Тогда

                   
СоответствиеТаблиц.Вставить(МассивПодразделений.Получить(кол-1), ТаблицаДвиженияДенежныхСредств);
                    Продолжить;

                КонецЕсли;

               
СоответствиеТаблиц.Вставить(МассивПодразделений.Получить(кол-1), ТаблицаДвиженияДенежныхСредств.Скопировать());

            КонецЦикла;
          

            ТаблицаДолей = МодульДоработок.ПолучитьТаблицуДолей(Дата, МассивПодразделений);       

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

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

                   
НоваяСтрока = времТаблицаДвиженияДенежныхСредств.Добавить();
                   
ЗаполнитьЗначенияСвойств(НоваяСтрока, Стр);
                   
НоваяСтрока.Проект      = Эл;
                  

                    //расходы распределяются пропорционально продажам за месяц
                   
СтрокаДолей = ТаблицаДолей.Найти(Эл, "Подразделение");

                   
НоваяСтрока.Сумма       = Стр.Сумма * СтрокаДолей.Доля;
                   
НоваяСтрока.СуммаУпр    = Стр.СуммаУпр * СтрокаДолей.Доля;                

                КонецЦикла;

            КонецЦикла;

           
//что было
            //Движения.ДвиженияДенежныхСредств.мПериод          = ДатаДвижений;
            //Движения.ДвиженияДенежныхСредств.мТаблицаДвижений = ТаблицаДвиженияДенежныхСредств;
            //Движения.ДвиженияДенежныхСредств.ВыполнитьДвижения();

            //что стало
           
Движения.ДвиженияДенежныхСредств.мПериод          = ДатаДвижений;
           
Движения.ДвиженияДенежныхСредств.мТаблицаДвижений = времТаблицаДвиженияДенежныхСредств;
           
Движения.ДвиженияДенежныхСредств.ВыполнитьДвижения();

        Иначе
           
//доработка+
           
ТаблицаДвиженияДенежныхСредств.ЗаполнитьЗначения(Ссылка.Подразделение, "Проект");

           
Движения.ДвиженияДенежныхСредств.мПериод          = ДатаДвижений;
           
Движения.ДвиженияДенежныхСредств.мТаблицаДвижений = ТаблицаДвиженияДенежныхСредств;
           
Движения.ДвиженияДенежныхСредств.ВыполнитьДвижения();

        КонецЕсли;
       
//доработка+ завершена

       ...
// здесь код не менялся

    КонецЕсли;

Самое интересное

- реализовать "соль" решения

Шаг 5. Таблица долей (коэффициентов) получается следующим образом:

Функция ПолучитьТаблицуДолей(ТекДата, СписокПодразделений) Экспорт

    Если Не
ЗначениеЗаполнено(ТекДата) Тогда
       
ТекДата = ТекущаяДата();
    КонецЕсли;

   
ТЗ = Новый ТаблицаЗначений;
   
ТЗ.Колонки.Добавить("Подразделение");
   
ТЗ.Колонки.Добавить("Доля");

   
Запрос = Новый Запрос;
   
Запрос.Текст = "ВЫБРАТЬ
    |   ПродажиОбороты.Подразделение,
    |   ПродажиОбороты.СтоимостьОборот КАК СтоимостьОборот
    |ИЗ
    |   РегистрНакопления.Продажи.Обороты(&НачалоПериода, &КонецПериода, , Подразделение В (&СписокПодразделений)) КАК ПродажиОбороты
    |
    |УПОРЯДОЧИТЬ ПО
    |   СтоимостьОборот УБЫВ
    |АВТОУПОРЯДОЧИВАНИЕ
"
;

   
Запрос.УстановитьПараметр("СписокПодразделений", СписокПодразделений);
   
Запрос.УстановитьПараметр("НачалоПериода", НачалоМесяца(ТекДата));
   
Запрос.УстановитьПараметр("КонецПериода", КонецМесяца(ТекДата));

   
ОбщиеПродажиЗаМесяц = МодульДоработок.ПолучитьОбщиеПродажиЗаМесяц(ТекДата, СписокПодразделений);

   
К = 1;
   
СуммаДолей = 0;

   
Выборка = Запрос.Выполнить().Выбрать();
    Пока
Выборка.Следующий() Цикл

        Если
К = СписокПодразделений.Количество() Тогда
           
Доля = 1 - СуммаДолей;
        Иначе
           
ПродажиЗаМесяц = Выборка.СтоимостьОборот;
           
Доля = Окр(ПродажиЗаМесяц/ОбщиеПродажиЗаМесяц,7);
           
СуммаДолей = СуммаДолей + Доля;
        КонецЕсли;

       
Стр = ТЗ.Добавить();
       
Стр.Подразделение = Выборка.Подразделение;
       
Стр.Доля = Доля;

    КонецЦикла;

    Возврат
ТЗ;

КонецФункции

 

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

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

Самое заключительное

- довести механизм до конечных показателей и отчетов

Шаг 6. Распределение административных расходов по подразделениям проводится в момент проведения документа. В конце месяца необходимо запустить групповое перепроведение документов. Для этого разработана обработка группового проведения документов - "Перепроведение документов за месяц" - перепроводятся только документы по административным расходам и имеющие заполненную таблицу "Распределение по подразделениям". В групповом перепроведении участвуют только документы вида ПлатежноеПоручениеИсходящее, ПлатежныйОрдерСписаниеДенежныхСредств, РасходныйКассовыйОрдер.

Шаг 7. Отчет по движению денежных средств строится по группировкам "Проект", "Статья движения денежных средств", остальные настройки - опционально при необходимости - "Вид денежных средств" (наличные, безналичные) , "Приход, расход".

Представленный механизм был реализован на платформе 8.3.11.3034 на конфигурации версии УТ 10.3.36.1.

С пользой для клиентов, RustIG (Rustем Iльдарович Gумеров)


См. также:

Как эффективно использовать Инфостарт NEW!

Список реализаций + структура подчиненности + реестр документов SALE'1sm

Список заказов поставщикам + структура подчиненности SALE'1sm

Список заказов покупателей + структура подчиненности SALE'1sm

Договоры для 1с-ника ТОП-скачиваний

Сетка расписания (Планировщик) нестанДАрт

Два механизма, которые ускорили работу бухгалтеров в 1С нестанДАрт

Мини-CRM для УТ 10.3

Расчет банковских (рабочих) дней нестанДАрт

Шаблоны кода в режиме 1С:Предприятие SALE'1sm

Доработка конфигурации Конвертация Данных

Планирование платежей. Прогнозирование прибылей и убытков

Ввод показателей план-факта БП 3.0 Know-how

Инвентаризация личного опыта Для новичков 1С

Большие запросы: взгляд на проблему нестанДАрт

Технология создания коммерческих разработок Know-how

Андроид-решение для создания заказов в 1С Know-how + нестанДАрт

Отчет Остатки и цены

Печать ценников с одной и двумя ценами 55х40, 100х60, 140х200

Загрузка данных о розничных продажах из магазинов Intimissimi (Интимиссими) и Calzedonia (Кальцедония)

Доработки обмена "УТ 10.3 - интернет-магазина Shop-Script"

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

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. tomvlad 3884 14.05.18 07:28 Сейчас в теме
А что, сейчас уже можно ссылку на свой сайт давать?
2. Rustig 1552 15.05.18 11:11 Сейчас в теме
3. tomvlad 3884 15.05.18 11:22 Сейчас в теме
(2) Раньше за такое Доржи бил линейкой по голове обещал строго наказать.
4. Rustig 1552 15.05.18 11:56 Сейчас в теме
(3) видимо, это было до внедрения модерации каждой статьи - сейчас модераторы не допускают статьи к публикации, если есть замечания
5. Rustig 1552 04.07.18 09:34 Сейчас в теме
(1) оказалось, что нельзя :)
удалил ссылку :(
6. strange2007 143 14.08.18 04:27 Сейчас в теме
Идея хорошая, но реализация сомнительная. Влазить в стандартную конфу как минимум не совсем разумно. Тем более если можно всё сделать в виде внешних идей. Оно и дешевле и более изолировано от других частей. Но это личное мнение, а не вселенская истина.
Недавно, например, делали распределение денег в ЗУПе тройке, в разрезе территорий (нет в стандартной нормального разделения, особенно если люди между территориями перемещаются по 10 раз в месяц). Две формочки, 2 настроечных регистра и всё. Конфу обновляю без проблем и финансовые гиганты пользуются достоверными цифрами.
7. Rustig 1552 14.08.18 09:30 Сейчас в теме
(6) все верно - согласен. если получается отделить ваш показатель задачи от типового расчета, то применяем свои регистры и алгоритмы в формочках. если не получается, то желательно адаптировать с минимальными потерями. я адаптировал минимально - обновление можно делать достаточно быстро - типовой код мало перемешан с моими доработками.
Одна из фищек моего решения - в технологии доработки - мне нравится что весь типовой код написан "блоками":
 //что было
            //Движения.ДвиженияДенежныхСредств.мПериод          = ДатаДвижений;
            //Движения.ДвиженияДенежныхСредств.мТаблицаДвижений = ТаблицаДвиженияДенежныхСредств;
            //Движения.ДвиженияДенежныхСредств.ВыполнитьДвижения();

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


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

что еще: есть такой журнал "Финансовый директор" - достаточно дорогой для приобретения - около 1000 р. Во всех номерах иллюстрируется работа с Эксель - насколько это отличный инструмент для финан. директора и аналитика. Какие там строятся громоздкие системы учета - просто ужас- и в журнале редко описываются технологии использования 1С, да и на ИС мало подобного... в общем, я хотел бы разрушить мнение ,что эксель это круто для финансового директора - 1с поинтереснее будет.
8. strange2007 143 14.08.18 09:47 Сейчас в теме
(7) Не подумайте, что я злостно критикую. Уверяю, любой метод хорош, если он приносит должный результат. Просто надо же немного пальцы погнуть (без зла).

По поводу екселя тоже аккуратно действуйте. Не забывайте, что ексель (равно как и кальк) очень гибкий инструмент для одного человека и в этом его преимущество перед учётными системами. Рекомендую ознакомиться с системой фин.планирования и бюджетирования Майкрософта. В ней как раз на самом нижнем уровне используют именно ексель. А вот выше уже начинаются учётные системы.
Из личного опыта могу сказать, что беда начинается как только ексель становится основополагающим во всём. Кстати, недавно в 1С перевёл екселевскую работу одного отдела и... у них почти не стало работы)))))
9. Rustig 1552 14.08.18 10:20 Сейчас в теме
(8)
Не подумайте, что я злостно критикую. Уверяю, любой метод хорош, если он приносит должный результат. Просто надо же немного пальцы погнуть (без зла).

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


(8)
ексель (равно как и кальк) очень гибкий инструмент для одного человека и в этом его преимущество перед учётными системами

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

(8)
беда начинается как только ексель становится основополагающим во всём

я описал свой опыт использования 1с, в ут - в уже готвой системе учета можно реализовать интересные управленческие идеи. Использование 1с в этом плане мало где описано. Для эксель-наработок выходит целый журнал, вокруг эксель создана индустрия - для финан.директоров - эксель продвигается и продается. Что-то подобного я не вижу в плане 1с.

(8)
недавно в 1С перевёл екселевскую работу одного отдела и

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

См. также

Список заказов покупателей (новый взгляд) Промо

Рабочее место Монитор заказов Оптовая торговля Монитор заказов Оптовая торговля v8 v8::ОУ КА1 УТ10 УУ Платные (руб)

Внешняя обработка "Список заказов покупателей". Фишка в том, что на одной форме отображается структура связанных документов с указанием контрагента. В этом окне также есть список товаров по заказу. Видны статусы заказов: исполнен, выполняется, черновик.

1350 руб.

16.08.2017    26267    69    60    

Программная работа с настройками СКД

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

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

27.01.2020    25442    ids79    26    

[СКД] Программное создание схемы компоновки данных

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Сделаем отчет на СКД полностью программно, без использования макета "схема компоновки данных".

15.01.2020    22920    John_d    22    

Последовательности событий. Шпаргалка

Практика программирования v8 Россия Бесплатно (free)

Собрал информацию о событиях/подписках/расширениях в одном месте.

30.12.2019    17475    kuzyara    33    

Как передать IP адрес, который вызвал HTTP запрос в 1C (для веб-сервера Apache)

Практика программирования v8 Бесплатно (free)

Столкнулся с задачей получения IP адреса, который вызывает http сервис 1С. Итак, решение:

22.11.2019    8245    Sibars    19    

Таблица значений. Нюансы

Практика программирования v8 Бесплатно (free)

Обзор некоторых аспектов использования общеизвестного инструмента 1С.

01.10.2019    32377    Yashazz    50    

[Шпаргалка] Программное создание элементов формы

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

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

06.09.2019    48271    rpgshnik    63    

Использование программных перечислений, ч.1: строковые константы Промо

Практика программирования v8 1cv8.cf Бесплатно (free)

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

10.12.2016    37218    unichkin    74    

Агрегатные функции СКД, о которых мало кто знает

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Пользуетесь ли Вы всеми возможными агрегатными функциями, которые предоставляет система компоновки данных? Если Вы используете только: СУММА, КОЛИЧЕСТВО, МИНИМУМ, МАКСИМУМ, СРЕДНЕЕ, то эта статья для Вас.

05.09.2019    48299    ids79    54    

Регистры бухгалтерии. Общая информация

Практика программирования Математика и алгоритмы v8 v8::БУ БУ Бесплатно (free)

Общая информация о внутреннем устройстве регистров бухгалтерии.

05.09.2019    27847    YPermitin    24    

Три костыля. Сказ про фокусы в коде

Практика программирования v8 Бесплатно (free)

Три интересных (или странных) костыля в коде, которые могут помочь в повседневных и не очень задачах.

03.09.2019    25314    YPermitin    80    

Вспомогательные инструкции в коде 1С Промо

Практика программирования v8 1cv8.cf Бесплатно (free)

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

15.10.2018    30058    tormozit    100    

Отслеживание выполнения фонового задания

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

Запуск фонового задания из модуля внешней обработки. Отслеживание выполнения задания в виде прогресса, расположенного на форме.

17.08.2019    31098    ids79    16    

Функции СКД: ВычислитьВыражение, ВычислитьВыражениеСГруппировкойМассив

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Подробное описание и использование внутренних функций системы компоновки данных: Вычислить, ВычислитьВыражение, ВычислитьВыражениеСГруппировкойМассив, ВычислитьВыражениеСГруппировкойТаблицаЗначений.

08.08.2019    79323    ids79    49    

Фоновое выполнение кода в 1С - это просто

Практика программирования v8 1cv8.cf Бесплатно (free)

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

02.08.2019    34325    avalakh    22    

Оформление и рефакторинг сложных логических выражений Промо

Практика программирования v8 Россия Бесплатно (free)

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

20.09.2012    77809    tormozit    131    

СКД - наборы данных и связи между ними, создание собственной иерархии, вложенные отчеты

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Набор данных объект. Использование в схеме компоновки нескольких наборов данных. Различные варианты связи наборов: объединение, соединение. Использование иерархии в отчетах на СКД. Создание собственной иерархии, иерархия детальных записей. Использование вложенных схем в отчетах на СКД.

26.07.2019    58029    ids79    11    

Как проводятся документы в типовых конфигурациях от 1С

Математика и алгоритмы Практика программирования Разработка v8::ОУ ERP2 УТ11 Россия УУ Бесплатно (free)

В свое время, когда только начинал шаги в 1С и изучал, как проводятся документы в конфигурациях на платформе 1С по книге "Разработка управляемого интерфейса" (Хрусталева Е.Ю.), и там были представлены примеры совсем далекие от того, как сейчас проводятся документы в современных конфигурациях от 1С.

24.07.2019    27171    skv_79    35    

СКД - использование расширений языка запросов, секция ХАРАКТЕРИСТИКИ

Инструментарий разработчика Практика программирования v8 v8::СКД Бесплатно (free)

Автоматическое и не автоматическое заполнение полей компоновки данных. Использование расширений языка запросов для СКД «{…}», секция ВЫБРАТЬ, секция ГДЕ, параметры виртуальных таблиц. Автоматизированное использование дополнительных данных в запросе: секция ХАРАКТЕРИСТИКИ.

17.07.2019    35374    ids79    27    

Запись значения в поле ввода/формы со срабатыванием события ПриИзменении Промо

Практика программирования v8 1cv8.cf Россия Бесплатно (free)

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

11.07.2007    48171    tormozit    41    

Регистры сведений. За кулисами

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Небольшие заметки по внутреннему устройству регистров сведений.

09.07.2019    25836    YPermitin    14    

"Меньше копипаста!", или как Вася универсальную процедуру писал

Практика программирования Разработка v8 v8::СКД 1cv8.cf Бесплатно (free)

Программист Вася разбирает подход создания универсальных методов на примере программного вывода СКД.

04.07.2019    19544    SeiOkami    50    

Создание отчетов с помощью СКД - основные понятия и элементы

Практика программирования Математика и алгоритмы v8 v8::СКД Бесплатно (free)

Основные принципы работы СКД. Понятия схемы компоновки и макета компоновки. Описание основных элементов схемы компоновки: наборы данных, поля, вычисляемые поля, ресурсы, параметры.

25.06.2019    51603    ids79    25    

Список заказов поставщикам (новая форма) + два ноу-хау для разработчиков Промо

Рабочее место Дебиторская и кредиторская задолженность Оптовая торговля Дебиторская и кредиторская задолженность Оптовая торговля v8 v8::ОУ КА1 УТ10 УУ Платные (руб)

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

1100 руб.

31.08.2017    21046    18    18    

Многопоточное ускорение однопользовательских нагрузок в 1С + Microsoft SQL Server 2017

Практика программирования Производительность и оптимизация (HighLoad) v8 v8::Запросы Бесплатно (free)

Взаимодействие с Microsoft SQL Server нередко вызывает трудности у 1С-ников, а потому интересны любые моменты, связанные с его использованием. О своем опыте работы с новым SQL Server 2017 участникам конференции Infostart-2018 рассказал директор ООО «Аналитика софт» Дмитрий Дудин.

11.06.2019    24811    dmurk    145    

Регистры накопления. Структура хранения в базе данных

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Структура хранения регистров накопления в базе данных для платформы 1С:Предприятие 8.x. Первая часть в серии публикаций.

16.05.2019    42374    YPermitin    30    

Выполнение внешней обработки в фоновом задании

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Подробное описание подхода к созданию длительной операции на основе внешней обработки. Реализация протестирована на 1С 8.3.12.1714 (x64).

11.05.2019    29241    Eret1k    23    

Как сделать из &НаКлиентеНаСервереБезКонтекста почти &НаКлиентеНаСервере Промо

Практика программирования v8 1cv8.cf Россия Бесплатно (free)

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

10.09.2017    44610    tormozit    74    

Выгрузка документа по условию

Практика программирования Разработка v8 Бесплатно (free)

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

25.04.2019    16008    m-rv    2    

Как прикрутить ГУИД к регистру сведений

Практика программирования Перенос данных из 1C8 в 1C8 Разработка v8 Бесплатно (free)

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

16.04.2019    20129    m-rv    17    

О расширениях замолвите слово...

Практика программирования Разработка v8 Бесплатно (free)

О чём стоит задуматься при принятии решения о создании расширения конфигурации…

07.04.2019    35107    ellavs    126    

Как сделать запрос на изменение данных Промо

Практика программирования v8 v8::Запросы 1cv8.cf Бесплатно (free)

В статье приведены особенности внутренней архитектуры и примеры работы с расширением языка запросов 1С.

01.06.2018    30458    m-rv    21    

Git-репозитории для 1С-кода (опыт использования при небольших проектах)

Практика программирования v8 Бесплатно (free)

Инструкции по взаимодействию с Git-репозиторием, которые писались для тех наших программистов, которые вообще никогда не работали с Git (руководства в духе "Как получить код из git-репозитория?", "Как отправить код в git-репозиторий")...

28.03.2019    27275    ellavs    88    

Трюки с внешними источниками данных

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Некоторые трюки для преодоления ограничений внешних источников данных.

14.03.2019    31113    YPermitin    53    

Возможности типовых шаблонов ограничения доступа на уровне записей (RLS)

Практика программирования БСП (Библиотека стандартных подсистем) Роли и права v8 v8::Права Бесплатно (free)

Краткий обзор применения типовых шаблонов ограничения доступа на уровне записей в конфигурациях, созданных на базе БСП: #ПоЗначениям, #ПоНаборамЗначений, #ПоЗначениямРасширенный, #ПоЗначениямИНаборамРасширенный

03.02.2019    38834    ids79    9    

Метод формирования движений в типовых регистрах нетиповыми регистраторами Промо

Практика программирования v8 1cv8.cf Бесплатно (free)

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

05.12.2017    28200    itriot11    34    

Как эффективно использовать Инфостарт

Личная эффективность Бесплатно (free)

Рекомендации, фишки, публикации Инфостарт

28.01.2019    11175    Rustig    66    

Новый подход к обмену данными EnterpriseData

Практика программирования Обмен через XML v8 v8::УФ Россия Бесплатно (free)

Хочу предложить Вашему вниманию цикл статей, посвященных обмену данными через универсальный формат (EnterpriseData или ED).

14.12.2018    41008    ids79    72    

Использование классов .Net в 1С для новичков Промо

Практика программирования Разработка внешних компонент Универсальные функции v7.7 v8 Бесплатно (free)

Руководство для новичков. Написав статью http://infostart.ru/public/238584/, я понял, что многие не понимают того, что написано. Поэтому в этой статье постараюсь более подробно остановиться на азах и без кода на вражеском языке (C#)

27.01.2016    76173    Serginio    108    

Программное заполнение пользовательских параметров и отборов СКД

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

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

13.11.2018    46758    Unk92    25    

Автоматические и управляемые блокировки применительно к типовым конфигурациям 1С

Математика и алгоритмы Практика программирования v8 v8::blocking 1cv8.cf Бесплатно (free)

Основные принципы работы с режимами автоматических и управляемых блокировок в 1С Предприятие 8. Теория и применение в типовых конфигурациях: БП, УТ, ЕРП

10.11.2018    34476    ids79    40    

Планирование платежей. Прогнозирование прибылей и убытков. Часть 1 про кассовый разрыв

Финансовые Финансовый учет и бюджетирование (FRP) Финансовый учет и бюджетирование (FRP) v8 v8::ОУ УТ10 УУ Абонемент ($m)

Кассовый разрыв. Планирование поступлений от клиентов, списаний налогов и оплат поставщикам. И как следствие - прогнозирование прибыли или убытков.

2 стартмани

21.10.2018    10212    1    Rustig    58    

Ввод показателей план-факта через табличный документ

Обработка документов Финансовый учет и бюджетирование (FRP) Финансовый учет и бюджетирование (FRP) v8 v8::БУ v8::УФ БП3.0 УУ Абонемент ($m)

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

2 стартмани

10.10.2018    8836    19    Rustig    10    

Доработки обмена "УТ 10.3 - интернет-магазина Shop-Script"

WEB Оптовая торговля Розничная торговля Учет ТМЦ Оптовая торговля Розничная торговля Учет ТМЦ v8 v8::ОУ УТ10 УУ Абонемент ($m)

Доработки типового обмена между УТ 10.3 и интернет-магазином Shop-Script на движке Webasyst: выгрузка нулевого количества товара, номенклатурных групп вместо групп номенклатуры и дополнительного описания номенклатуры.

2 стартмани

07.09.2018    8857    2    Rustig    0    

Произвольный код в фоновом режиме

Практика программирования v8 1cv8.cf Бесплатно (free)

Задача: реализовать выполнение произвольного кода в фоновом режиме без изменения конфигурации, т.е. во внешней обработке.

03.09.2018    27765    zarankony    42    

Основные понятия и механизмы оптимизации клиент-серверного взаимодействия в 1C

Математика и алгоритмы Практика программирования v8 Россия Бесплатно (free)

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

23.08.2018    38246    Rain88    46