Расчет суммы и НДС в табличной части документа

24.11.23

Разработка - Работа с интерфейсом

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

Давайте начнем с создания документа "ПоступлениеТоваров" с табличной частью "СписокТоваров". В этой табличной части мы добавим три числовых реквизита: "Цена", "Сумма" и "Количество".

Теперь перейдем в форму документа, чтобы оценить результат:

 

 

Отлично, теперь давайте добавим подвал к табличной части "СписокТоваров", где будет рассчитываться общий итог. Для этого выполним следующие шаги:

  1. Откройте форму документа "ПоступлениеТоваров".
  2. Перейдите в режим дизайна формы.
  3. Выберите табличную часть "СписокТоваров".
  4. Перейдите во вкладку "Использование".
  5. Установите галочку напротив опции "Подвал".

 

Добавим в подвале расчет общей суммы и прочих итогов. Произведем следующие изменения:

  1. Реквизит "Цена" в Подвале:

    • Нажмите на реквизит "Цена" в табличной части.
    • В тексте подвала укажите "Итого".
  2. Реквизит "Сумма" в Подвале:

    • Нажмите на реквизит "Сумма" в табличной части.
    • Перейдите во вкладку "Использование".
    • В разделе "Путь к данным подвала" выберите "Объект.СписокТоваров.ИтогСумма".

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

Отлично, если вы хотите добавить автосуммирование для реквизита "Количество" при изменении, вставьте следующий код в событие "ПриИзменении" на клиенте:

&НаКлиенте
Процедура СписокТоваровКоличествоПриИзменении(Элемент)
	Строка=Элементы.СписокТоваров.ТекущиеДанные;
	Строка.Сумма=Строка.Количество*Строка.Цена;  
КонецПроцедуры

Если вы хотите добавить автосуммирование для реквизита "Цена" при изменении, вставьте следующий код в событие "ПриИзменении" на клиенте:

&НаКлиенте
Процедура СписокТоваровЦенаПриИзменении(Элемент)
Строка=Элементы.СписокТоваров.ТекущиеДанные;
Строка.Сумма=Строка.Количество*Строка.Цена; 	
КонецПроцедуры

 

Чтобы автоматически рассчитать НДС, вставляем в сам документ реквизит с именем "НДС" и числовым значением. Располагаем его на форме по вашему усмотрению, добавляя заголовок, например, "В том числе НДС:". Применяем следующий код, внедряя надписи к цене и количеству:
    

	Объект.НДС=Объект.СписокТоваров.Итог("Сумма")/120*20; 


Вот так должно получиться:

&НаКлиенте
Процедура СписокТоваровКоличествоПриИзменении(Элемент)
	Строка=Элементы.СписокТоваров.ТекущиеДанные;
	Строка.Сумма=Строка.Количество*Строка.Цена;  
	Объект.НДС=Объект.СписокТоваров.Итог("Сумма")/120*20; 
КонецПроцедуры


&НаКлиенте
Процедура СписокТоваровЦенаПриИзменении(Элемент)
    Строка=Элементы.СписокТоваров.ТекущиеДанные;
	Строка.Сумма=Строка.Количество*Строка.Цена; 
	Объект.НДС=Объект.СписокТоваров.Итог("Сумма")/120*20; 	
КонецПроцедуры


Как можно заметить, считает все хорошо:

 

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

 

 

Вносим необходимые изменения: переименовываем заголовок в "Всего наименований". Для отображения суммы прописью, используем "ИтогСумма". Заголовок "На сумму" изменяем, добавляем декоративную надпись "руб", объединяем все в группу. В результате получаем следующий итог:

 

 

Добавим "декорацию-надпись" на форму и назовем ее "пропись". Затем добавим следующий код к нашей цене и количеству при изменении:   

	Элементы.Пропись.Заголовок=ЧислоПрописью( Объект.СписокТоваров.Итог("Сумма"), "Л=ru_RU", "рубль, рубля, рублей, м, копейка, копейки, копеек, ж, 2"

 

Конечный код:

&НаКлиенте
Процедура СписокТоваровКоличествоПриИзменении(Элемент)
	Строка=Элементы.СписокТоваров.ТекущиеДанные;
	Строка.Сумма=Строка.Количество*Строка.Цена;  
	Объект.НДС=Объект.СписокТоваров.Итог("Сумма")/120*20; 
	Элементы.Пропись.Заголовок=ЧислоПрописью( Объект.СписокТоваров.Итог("Сумма"), "Л=ru_RU", "рубль, рубля, рублей, м, копейка, копейки, копеек, ж, 2");
КонецПроцедуры


&НаКлиенте
Процедура СписокТоваровЦенаПриИзменении(Элемент)
	Строка=Элементы.СписокТоваров.ТекущиеДанные;
	Строка.Сумма=Строка.Количество*Строка.Цена; 
	Объект.НДС=Объект.СписокТоваров.Итог("Сумма")/120*20; 
	Элементы.Пропись.Заголовок=ЧислоПрописью( Объект.СписокТоваров.Итог("Сумма"), "Л=ru_RU", "рубль, рубля, рублей, м, копейка, копейки, копеек, ж, 2");	
КонецПроцедуры

 

 

Важное замечание. Чтобы все вычисления происходили и при открытии, необходимо также добавить тот же код в событие "ПриОткрытии":
 

&НаКлиенте
Процедура ПриОткрытии(Отказ)
    Объект.НДС=Объект.СписокТоваров.Итог("Сумма")/120*20; 
	Элементы.Пропись.Заголовок=ЧислоПрописью( Объект.СписокТоваров.Итог("Сумма"), "Л=ru_RU", "рубль, рубля, рублей, м, копейка, копейки, копеек, ж, 2");
КонецПроцедуры

Проверяем, и все считает и прописывает идеально:

 

 

См. также

Богатый редактор картинок, хранимых в базе, с возможностью РИСОВАНИЯ. Редактор внешних файлов картинок. Объект, расширяющий возможности работы с картинками из встроенного языка (Три в одном) + Обработка «Стандартизация картинок»

Работа с интерфейсом Рабочее место Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Обработка предназначена для редактирования картинок в режиме «Предприятие», с возможностью РИСОВАТЬ на них. Поддерживается работа как в обычных формах (толстый клиент) так и на управляемых формах (тонкий клиент). Обработка позволяет редактировать как картинки, хранимые в базе, так и графические файлы с диска на файловой системе. Помимо базовых функций (изменение размеров, преобразование формата, обрезание картинки, повороты и т.п.) – редактор имеет богатый набор инструментов для рисования. Доступна функция вставки изображения из буфера обмена. Также обработка может быть использована из встроенного языка как объект для редактирования картинок. Объект может быть использован: на стороне клиента, на стороне сервера, из внешнего соединения. Данная обработка будет особенно полезна тем, кто вносит картинки в базу (изображения номенклатуры, фотографии физических лиц и т.п.). Функционал реализуется с использованием JavaScript и бесплатного ПО ImageMagick (без использования внешних компонент).

6000 руб.

16.01.2015    62103    43    59    

81

[Расширения] Динамическое управление видимостью и доступностью элементов форм (УФ) (8.3.6+)

Работа с интерфейсом Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

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

5000 руб.

14.01.2016    54702    16    21    

42

Управление дашбордами

Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Обработка предназначена для создания и управления дашбордами.

2400 руб.

29.06.2020    16907    22    4    

36

Новогоднее оформление для 1С

Работа с интерфейсом Платформа 1С v8.3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 Бесплатно (free)

Добавьте новогоднего настроения! Расширение создает декорацию в виде гирлянды на некоторых формах объектов.

27.12.2023    11176    762    elcoan    45    

106

Конструктор HTML, CSS и javascript

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

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

2 стартмани

10.04.2023    9892    153    acces969    31    

119

Модель состояния для MVC

Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

"MVC плохо применима в 1С" - познакомьтесь с моделью состояния и, возможно, ваше мнение поменяется! Представленное решение является эволюционным развитием идеи реализации MVC для 1С. В новой версии добавлены DSL для описания модели состояния, а также параметризация свойств параметров и элементов формы.

1 стартмани

05.07.2022    3945    kalyaka    4    

29

Табло очереди заказов на экран телевизора

WEB-интеграция Работа с интерфейсом Платформа 1С v8.3 1С:Розница 2 Платные (руб)

Связка из веб-приложения и расширения для 1С: Розница 2.3.

3600 руб.

29.04.2022    12298    1    5    

10

Условное оформление элементов форм в пользовательском режиме 1С (управление видимостью и доступностью элементов форм)

Работа с интерфейсом Платформа 1С v8.3 Платные (руб)

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

6000 руб.

18.01.2022    8956    1    2    

6
Внимание! Тема закрыта. Добавлять сообщения в закрытую тему запрещено.
Отзывы
1. insurgut 207 26.11.23 21:01 Сейчас в теме
Есть только нюанс небольшой... округление...

СуммаНДС_Построчно = 0;
Для Каждого СтрокаТЧ Из Объект.СписокТоваров Цикл
     СуммаНДС_Построчно = СуммаНДС_Построчно + Окр(СтрокаТЧ.Сумма / 120 * 20, 2);
КонецЦикла;


...и вот СуммаНДС_Построчно не всегда равно Объект.СписокТоваров.Итог("Сумма") / 120 * 20
artbear; user1854482; t278; +3 Ответить
Остальные комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. insurgut 207 26.11.23 21:01 Сейчас в теме
Есть только нюанс небольшой... округление...

СуммаНДС_Построчно = 0;
Для Каждого СтрокаТЧ Из Объект.СписокТоваров Цикл
     СуммаНДС_Построчно = СуммаНДС_Построчно + Окр(СтрокаТЧ.Сумма / 120 * 20, 2);
КонецЦикла;


...и вот СуммаНДС_Построчно не всегда равно Объект.СписокТоваров.Итог("Сумма") / 120 * 20
artbear; user1854482; t278; +3 Ответить
2. jmw 60 29.11.23 11:41 Сейчас в теме
Есть ещё один ньюанс: ставка НДС не всегда равна 20%.
Ещё совсем недавно основная ставка НДС была 18%.
И кроме основной ещё есть льготная — 10%, а есть товары и услуги к которым НДС вообще не применяется…
Это всё нужно как-то учесть!
3. Starliner 06.12.23 13:35 Сейчас в теме
Да и код, который повторяется более 1 раза, лучше вытащить в процедуру
4. user1990108 21.12.23 15:32 Сейчас в теме
Подскажите, как вывести на печать реквизиты на форме "В том числе НДС", "Итого", "Всего наименований" и "Пропись"?
5. RandNoName 26.03.24 12:19 Сейчас в теме
Ой, как все правильно и понятно спасибо большое за статью
6. пользователь 26.03.24 12:42
Сообщение было скрыто модератором.
...
7. user2024152 26.03.24 12:51 Сейчас в теме
.  СериализаторXDTO.ЗаписатьXML (ЗаписьXML, ОбъектЗаказ); 
  
 Стр = Новый Структура; 
 Стр.Вставить ("типОбъекта", "ДокументОбъект.Заказ"); 
 Стр.Вставить ("СтрокаXML", ЗаписьXML.Закрыть()) ; 
 МассивОбъектов = Новый Массив; 
 МассивОбъектов.Добавить(Стр); 
  
 ХранилищеЗначений = Новый ХранилищеЗначения (МассивОбъектов, Новый СжатиеДанных (9)); 
  
 Попытка 
  Результат = Соединение.UpdateObject(ХранилищеЗначений); 
 Исключение 
  Сообщить(ОписаниеОшибки()); 
  Возврат Ложь; 
 КонецПопытки; 
  
 Возврат Результат; 
Конецфункции 
 
 
справочник 
 
Процедура ПриЗаписи(Отказ) 
 Обмен.ОбновитьДанныеИнженер(ЭтотОбъект); 
КонецПроцедуры 
 
 
общие команды 
 
&НаКлиенте 
Процедура ОбработкаКоманды(ПараметрКоманды, ПараметрыВыполненияКоманды) 
 Обмен.ОбновитьДанные(); 
КонецПроцедуры  
Показать
8. пользователь 26.03.24 12:52
Сообщение было скрыто модератором.
...
9. пользователь 26.03.24 13:05
Сообщение было скрыто модератором.
...
Оставьте свое сообщение