В этой статье описываются полезные функции и процедуры, помогающие эффективно работать с различными типами данных в системе "1С:Предприятие 7.7".
* Обработка з
на чений
* Форматирование
* Список з
на чений
* Таблица з
на чений
* Таблица
* Период и дата
* Календари и праздники
* Справочники
* Документы
* Предопределённые функции
* Налоговый учёт
Обработка зна чений в 1С
Код //функция проверяет, является ли переданный в функцию Символ числом
Функция ЭтоЧисло(Символ) Экспорт
Если (КодСимв(Символ)>=48) И (КодСимв(Символ)<=57) Тогда
Возврат(1);
И
на че
Возврат(0);
КонецЕсли;
КонецФункции
//функция возвращает копейки
Функция гКопейки(З
на чение) Экспорт
Грн=Цел(З
на чение);
Коп=З
на чение-Грн;
Возврат(Коп
0);
КонецФункции
//функция возвращает сумму без скидки
Функция гСкидка(Сумма,Скидка) Экспорт
Возврат Сумма*(1-Скидка/100);
КонецФункции
//функция уста
на вливает новое з
на чение реквизита документа или справочника и задаёт вопрос, если новое з
на чение не соответствует предыдущему
Функция гЗ
на чение(Ко,Атрибут,З
на чение) Экспорт
З
на ч1=Ко.ПолучитьАтрибут(Атрибут);
З
на ч2=З
на чение;
//проверка
Если Не(ТипЗ
на ченияСтр(З
на ч1)=ТипЗ
на ченияСтр(З
на ч2)) Тогда
//несоответствие типов
Возврат(0);
И
на чеЕсли Не(ТипЗ
на ченияСтр(З
на ч2)="Число") И (ПустоеЗ
на чение(З
на ч2)=1) Тогда
//пустое новое з
на чение
Возврат(0);
КонецЕсли;
//реквизит
Если Метаданные.Документ(Ко.Вид()).Выбран()=1 Тогда
//документ
Если Метаданные.Документ(Ко.Вид()).РеквизитШапки(Атрибут).Выбран()=1 Тогда
Ж=Метаданные.Документ(Ко.Вид()).РеквизитШапки(Атрибут);
Имя=Ж.Представление();
И
на чеЕсли Метаданные.Документ(Ко.Вид()).РеквизитТабличнойЧасти(Атрибут).
Выбран()=1 Тогда
Ж=Метаданные.Документ(Ко.Вид()).РеквизитТабличнойЧасти(Атрибут);
Имя=Ж.Представление()+" (строка "+Ко.НомерСтроки+")";
И
на че
Ж=Метаданные.ОбщийРеквизитДокумента(Атрибут);
Имя=Ж.Представление();
КонецЕсли;
И
на чеЕсли Метаданные.Справочник(Ко.Вид()).Выбран()=1 Тогда
//справочник
Ж=Метаданные.Справочник(Ко.Вид()).Реквизит(Атрибут);
Имя=Ж.Представление();
Если ПустаяСтрока(Имя)=1 Тогда
Имя=Атрибут;
КонецЕсли;
КонецЕсли;
//форматирование
Если ТипЗ
на ченияСтр(З
на ч2)="Строка" Тогда
З
на ч1=СокрЛП(З
на ч1);
З
на ч2=СокрЛП(З
на ч2);
И
на чеЕсли ТипЗ
на ченияСтр(З
на ч2)="Число" Тогда
З
на ч2=Окр(З
на ч2,Ж.Точность);
КонецЕсли;
//проверка
Если З
на ч1=З
на ч2 Тогда
Возврат(0);
КонецЕсли;
//установка з
на чения
Если ПустоеЗ
на чение(З
на ч1)=0 Тогда
Текст=
"Атрибут: "+Имя+"
|
|Старое з
на чение: "+СимволТабуляции+З
на ч1+"
|Новое з
на чение: "+СимволТабуляции+З
на ч2+"
|
|Установить новое з
на чение?";
Если Вопрос(Текст,"Да+Нет")="Нет" Тогда
Возврат(0)
КонецЕсли;
КонецЕсли;
//з
на чение
Ко.УстановитьАтрибут(Атрибут,З
на ч2);
Возврат(1);
КонецФункции
Форматирование данных в 1С
Код //форматирование числа
Функция гЧисло(Зна чение,Зна ки=2) Экспорт
Ответ=Формат(Зна чение,"Ч18."+Зна ки);
Возврат СокрЛП(Ответ);
КонецФункции
//функция убирает лишние пробелы
Функция гСжатьПробелы(аТекст) Экспорт
Текст=СокрЛП(аТекст);
//пробелы
Замена =Формат(" ","С5");
Для й=1 По 4 Цикл
Зна к=Сред(Замена ,й);
Текст=СтрЗаменить(Текст,Зна к," ");
КонецЦикла;
//
Возврат СокрЛП(Текст);
КонецФункции
//функция возвращает переданную строку, в которой первая буква устана вливается в верхнем или в нижнем регистре
Функция гБуква(Текст,ФлагНрег=0) Экспорт
Буква=Лев(Текст,1);
Если ФлагНрег=0 Тогда
Буква=ВРег(Буква);
Ина че
Буква=НРег(Буква);
КонецЕсли;
Возврат(Буква+Сред(Текст,2));
КонецФункции
/функция возвращает представление переданного документа
Функция гПредставлениеДокумента(Д) Экспорт
Возврат Д.ПредставлениеВида()+" "+СокрЛП(Д.НомерДок)+" ("+Д.ДатаДок+")";
КонецФункции
//процедура выдаёт сообщение при проведении документа
Процедура гСообщить(Ко,Текст,НомерСтроки=0,Символ="!") Экспорт
//сигна л
Если Ко.Ошибка=0 Тогда
Сигна л();
КонецЕсли;
//документ
Документ=""+Ко.ДатаДок+" "+Ко.ПредставлениеВида()+" "+СокрЛП(Ко.НомерДок);
//номер строки
Если НомерСтроки>0 Тогда
Документ=Документ+" (строка "+НомерСтроки+")";
КонецЕсли;
//сообщение
Сообщить(Документ+": "+Текст,Символ);
КонецПроцедуры
Список зна чений в 1С
Код //процедура выполняется при добавлении нового зна чения в интерактивный список зна чений
Процедура сзДобавить(Список,Тип,Вид,Длина ,Точность,Подсказка) Экспорт
//тип
Если (Тип="Справочник") Или (Тип="Документ") Тогда
Тип=Тип+"."+Вид;
КонецЕсли;
//зна чение
Если Список.ТекущаяСтрока()=0 Тогда
Зна чение="";
Ина че
Зна чение=Список.ПолучитьЗна чение(Список.ТекущаяСтрока());
КонецЕсли;
//выбор
Если ВвестиЗна чение(Зна чение,Подсказка,Тип,Длина ,Точность)=1 Тогда
Список.ДобавитьЗна чение(Зна чение);
КонецЕсли;
КонецПроцедуры
//процедура выполняется для изменения зна чения интерактивного списка зна чений
Процедура сзИзменить(Список) Экспорт
Позиция=Список.ТекущаяСтрока();
Если Позиция=0 Тогда
Возврат;
КонецЕсли;
//
Зна чение=Список.ПолучитьЗна чение(Список.ТекущаяСтрока());
Тип=ТипЗна ченияСтр(Зна чение);
Если (Тип="Справочник") Или (Тип="Документ") Тогда
Тип=Тип+"."+Зна чение.Вид();
Подсказка=Зна чение.Вид();
Ина че
Подсказка=Тип;
КонецЕсли;
Если ВвестиЗна чение(Зна чение,Подсказка,Тип)=1 Тогда
Список.УстановитьЗна чение(Позиция,Зна чение);
КонецЕсли;
КонецПроцедуры
//процедура выполняется при удалении зна чения из интерактивного списка зна чений
Процедура сзУдалить(Список) Экспорт
Если Список.ТекущаяСтрока()>0 Тогда
Список.УдалитьЗна чение(Список.ТекущаяСтрока());
КонецЕсли;
КонецПроцедуры
//процедура изменяет позицию зна чения интерактивного списка зна чений
Процедура сзСдвинуть(Список,Количество) Экспорт
Если (Количество>0) И (Список.ТекущаяСтрока()=Список.РазмерСписка()) Тогда
Количество=1-Список.РазмерСписка();
Ина чеЕсли (Количество<0) И (Список.ТекущаяСтрока()=1) Тогда
Количество=Список.РазмерСписка()-1;
КонецЕсли;
Список.СдвинутьЗна чение(Количество,Список.ТекущаяСтрока());
КонецПроцедуры
//функция проверяет на личие в списке зна чений с пометками хотя бы одного помеченного зна чения
Функция сзПометка(Список) Экспорт
Для i=1 По Список.РазмерСписка() Цикл
Если Список.Пометка(i)=1 Тогда
Возврат(1);
КонецЕсли;
КонецЦикла;
//нет пометок
Возврат(0);
КонецФункции
//функция помечает или снимает пометку для всех зна чений списка
Процедура сзПометить(Список,Флаг) Экспорт
Для й=1 По Список.РазмерСписка() Цикл
Список.Пометка(й,Флаг);
КонецЦикла;
КонецПроцедуры
//процедура оставляет в списке зна чений заданное количество зна чений
Процедура сзОбрезать(Список,Размер) Экспорт
Если Список.РазмерСписка()>Размер Тогда
Количество=Список.РазмерСписка()-Размер;
Список.УдалитьЗна чение(Размер+1,Количество);
КонецЕсли;
КонецПроцедуры
//функция выгружает зна чения колонки таблицы зна чений в список зна чений
Функция сзКолонка(М,Колонка) Экспорт
Список=СоздатьОбъект("СписокЗна чений");
//
В=СоздатьОбъект("ТаблицаЗна чений");
М.Выгрузить(В,,,Колонка);
В.Свернуть(Колонка,);
В.Выгрузить(Список,,,Колонка);
Возврат(Список);
КонецФункции
//процедура преобразует строку со зна чениями в список зна чений
Процедура сзПарсить(Список,Текст) Экспорт
Если ПустаяСтрока(Текст)=0 Тогда
Если Найти(Текст,"=")=0 Тогда
//делитель - Запятая
Зна чение=СтрЗаменить(СокрЛП(Текст),",",Симв(34)+","+Симв(34));
Зна чение=Симв(34)+Зна чение+Симв(34);
Список.ИзСтрокиСРазделителями(Зна чение);
Ина че
//делитель - Точка с запятой
Текст=СтрЗаменить(Текст,";",РазделительСтрок);
Для й=1 По Текст.КоличествоСтрок() Цикл
Стр=Текст.ПолучитьСтроку(й);
Если ПустаяСтрока(Стр)=0 Тогда
Позиция=Найти(Стр,"=");
Если Позиция>0 Тогда
Идентификатор=Лев(Стр,Позиция-1);
Зна чение=Сред(Стр,Позиция+1);
Список.Установить(СокрЛП(Идентификатор),СокрЛП(Зна чение));
Ина че
Список.ДобавитьЗна чение(СокрЛП(Стр));
КонецЕсли;
КонецЕсли;
КонецЦикла;
КонецЕсли;
КонецЕсли;
КонецПроцедуры
//процедура позиционирует строку списка зна чений на заданном зна чении
Процедура сзУстановить(Список,Зна чение) Экспорт
Позиция=Список.НайтиЗна чение(Зна чение);
Если Позиция>0 Тогда
Список.ТекущаяСтрока(Позиция);
КонецЕсли;
КонецПроцедуры
Таблица зна чений в 1С
Код //процедура сдвигает строку в таблице зна чений;
//если сдвигается последняя строка вниз, то строка становится первой;
//если сдвигается первая строка вверх, то строка перемещается в конец таблицы зна чений
Процедура Количество=1-М.КоличествоСтрок();
Ина чеЕсли (Количество<0) И (М.ТекущаяСтрока()=1) Тогда
Количество=М.КоличествоСтрок()-1;
КонецЕсли;
М.СдвинутьСтроку(Количество,М.ТекущаяСтрока())());
КонецПроцедуры
//процедура обнуляет зна чения таблицы зна чений вниз от заданной строки и вправо от заданной колонки
Процедура тзОбнулить(М,НомерСтр,НомерКол) Экспорт
Для i=НомерСтр По М.КоличествоСтрок() Цикл
Для j=НомерКол По М.КоличествоКолонок() Цикл
М.УстановитьЗна чение(i,j,0);
КонецЦикла;
КонецЦикла;
КонецПроцедуры
//процедура удаляет строку в интерактивной таблице зна чений> Процедура тзУдалитьСтроку(М) Экспорт
//запомина ние текущей строки
ТекСтрока=М.ТекущаяСтрока()-1;
//удаление
М.УдалитьСтроку();
//позиционирование
Если М.КоличествоСтрок()>0 Тогда
ТекСтрока=Мин(ТекСтрока,М.КоличествоСтрок());
М.ТекущаяСтрока(ТекСтрока);
КонецЕсли;
КонецПроцедуры
//процедура на ходит документ с заданным номером в таблице зна чений с документами
Процедура гЖурна л_Найти(М) Экспорт
НомерДок=0;
Если ВвестиЧисло(НомерДок,"Номер документа",5,0)=1 Тогда
//поиск по номеру в выборке
Если М.НайтиЗна чение(НомерДок,,"Номер")=0 Тогда
Предупреждение("Документ № "+НомерДок+" не на йден");
Возврат;
КонецЕсли;
//поиск документа
Список=СоздатьОбъект("СписокЗна чений");
М.ВыбратьСтроки();
Пока М.ПолучитьСтроку()=1 Цикл
Если М.Номер=НомерДок Тогда
Список.ДобавитьЗна чение(М.ТекущийДокумент);
КонецЕсли;
КонецЦикла;
//выбор
Зна чение="";
Если Список.РазмерСписка()=1 Тогда
Зна чение=Список.ПолучитьЗна чение(1);
Ина чеЕсли Список.ВыбратьЗна чение(Зна чение,"Выбор документа")=0 Тогда
Возврат;
КонецЕсли;
//позиционирование
НомерСтр=0;
М.НайтиЗна чение(Зна чение,НомерСтр,"ТекущийДокумент");
М.ТекущаяСтрока(НомерСтр);
КонецЕсли;
КонецПроцедуры
Таблица или печатна я форма в 1С
Код //установление автоширины колонок таблицы
Процедура гАвтоШирина Колонок(Таб,НачКол,НачСтр) Экспорт
Для НомерКол=НачКол По Таб.Ширина Таблицы() Цикл
МаксШирина =0;
Для НомерСтр=НачСтр По Таб.ВысотаТаблицы() Цикл
ТекШирина =СтрДлина (Таб.Область(НомерСтр,НомерКол).Текст);
МаксШирина =Макс(МаксШирина ,ТекШирина );
КонецЦикла;
Таб.Область(,НомерКол).Ширина Столбца(МаксШирина +2);
КонецЦикла;
КонецПроцедуры
Периоды и даты в 1С
Код //функция проверяет, равен ли месяцу интервал между заданными датами
Функция ЭтоМесяц(ДатаН,ДатаК) Экспорт
Если Не(ДатаН=НачМесяца(ДатаН)) Тогда
Возврат(0);
Ина чеЕсли Не(ДатаК=КонМесяца(ДатаК)) Тогда
Возврат(0);
Ина чеЕсли ДатаН=НачМесяца(ДатаК) Тогда
Возврат(1);
Ина че
Возврат(0);
КонецЕсли;
КонецФункции
//функция возвращает количество полных месяцев между датами
Функция гМесяцев(ДатаН,ДатаК) Экспорт
Если ДатаН<ДатаК Тогда
ТекДата=НачМесяца(ДатаН);
Зна чение=1;
Пока ТекДата<НачМесяца(ДатаК) Цикл
ТекДата=ДобавитьМесяц(ТекДата,1);
Зна чение=Зна чение+1;
КонецЦикла;
Возврат(Зна чение);
Ина че
Возврат(0);
КонецЕсли;
КонецФункции
//функция определяет порядковый номер месяца в квартале
Функция гМесяцКвартала(ДатаДок) Экспорт
НачМесяц=ДатаМесяц(НачКвартала(ДатаДок));
КонМесяц=ДатаМесяц(ДатаДок);
Возврат(КонМесяц-НачМесяц+1);
КонецФункции
//функция определяет порядковый номер квартала по дате
Функция гДатаКвартал(аДата) Экспорт
Возврат ДатаМесяц(КонКвартала(аДата))/3;
КонецФункции
Календари и праздники в 1С
Код //ф//функция возвращает дату, на ходящуюся на определённом интервале дней от заданной даты, без учёта выходных;
//на пример, используется для определения конечной даты действия счёта-фактуры
Функция an class="color-blue">гСрокДействия(ДатаДок,Период,Вид="Основной") Экспорт
К=СоздатьОбъект("Календарь."+Вид);
К.УчитыватьПраздники(1);
Если К.Автозаполнение(ДатаДок,ДобавитьМесяц(ДатаДок+Период,1))=1 Тогда
Возврат К.ПолучитьДату(ДатаДок,Период);
КонецЕсли;
КонецФункции
//функция определяет количество рабочих дней в интервале дат
Функция гРабочиеДни(ДатаН,ДатаК,Вид="Основной") Экспорт
К=СоздатьОбъект("Календарь."+Вид);
К.УчитыватьПраздники(1);
Если К.Автозаполнение(ДатаН,ДатаК)=1 Тогда
Возврат К.Дней(ДатаН,ДатаК);
КонецЕсли;
КонецФункции
//функция определяет количество праздничных дней в интервале дат
Функция гПраздники(ДатаН,ДатаК) Экспорт
Кол=0;
//
П=СоздатьОбъект("Праздники");
П.ВыбратьДаты(ДатаН,ДатаК);
Пока П.СледующаяДата()=1 Цикл
Если НомерДняНедели(П.Дата)<6 Тогда
Кол=Кол+1;
КонецЕсли;
КонецЦикла;
//
Возврат(Кол);
КонецФункции
Справочники в 1С
Код //функция возвращает элемент заданного справочника по зна чению реквизита "Счет"
Функция сНайтиПоСчету(Счет,Справочник,Реквизит="Счет") Экспорт
С=СоздатьОбъект("Справочник."+Справочник);
Если С.НайтиПоРеквизиту(Реквизит,Счет,1)=1 Тогда
Возврат С.ТекущийЭлемент();
Ина че
Возврат ПолучитьПустоеЗна чение("Справочник."+Справочник);
КонецЕсли;
КонецФункции
//функция возвращает элемент заданного справочника по полному коду элемента
Функция сНайтиПоКоду(Справочник,Код) Экспорт
С=СоздатьОбъект("Справочник."+Справочник);
Если С.НайтиПоКоду(Код,2)=1 Тогда
Возврат С.ТекущийЭлемент();
Ина че
Возврат ПолучитьПустоеЗна чение("Справочник."+Справочник);
КонецЕсли;
КонецФункции
//функция возвращает элемент заданного справочника по
//на именованию
//если элемент отсутствует в справочнике, то создаётся новый
Функция сНайтиПоНаименованию(Справочник,Наименование) Экспорт
С=СоздатьОбъект("Справочник."+Справочник);
Если С.НайтиПоНаименованию(Наименование,0,1)=0 Тогда
С.Новый();
С.Наименование=Наименование;
С.Записать();
Сообщить("Справочник "+Справочник+": Новый элемент "+Наименование);
КонецЕсли;
Возврат(С.ТекущийЭлемент());
КонецФункции
//процедура удаляет заданный элемент справочника
Процедура гЭлемент_Удалить(Элемент,Флаг) Экспорт
С=СоздатьОбъект("Справочник."+Элемент.Вид());
С.НайтиЭлемент(Элемент);
С.Удалить(Флаг);
КонецПроцедуры
//функция возвращает строку вида "Иванов И.И." из переданной в функцию строки вида "Иванов Иван Иванович"
Функция гФио_Получить(Зна чение)
Стр=гФорматС(Зна чение);
Стр=СтрЗаменить(Стр," ",РазделительСтрок);
Если СтрКоличествоСтрок(Стр)=1 Тогда
Фио=СокрЛП(Стр);
Ина чеЕсли СтрКоличествоСтрок(Стр)=2 Тогда
СтрФ=СтрПолучитьСтроку(Стр,1);
СтрИ=СтрПолучитьСтроку(Стр,2);
Фио=СокрЛП(СтрФ)+" "+Лев(СокрЛП(СтрИ),1)+".";
Ина че
СтрО=СтрПолучитьСтроку(Стр,СтрКоличествоСтрок(Стр));
СтрИ=СтрПолучитьСтроку(Стр,СтрКоличествоСтрок(Стр-1));
СтрФ="";
Для й=1 По СтрКоличествоСтрок(Стр)-2 Цикл
СтрФ=СтрФ+" "+СтрПолучитьСтроку(Стр,й);
КонецЦикла;
Фио=СокрЛП(СтрФ)+" "+Лев(СокрЛП(СтрИ),1)+"."+Лев(СокрЛП(СтрО),1)+".";
КонецЕсли;
Возврат(Фио);
КонецФункции
//функция открывает подбор из справочника и предоставляет пользователю выбор из элементов фиксированной группы
Функция сПодборРодитель(Ко,Родитель,Элемент,Заголовок="")
Экспорт
Ко.ОткрытьПодбор("Справочник."+Родитель.Вид(),"ДляВыбора",,0);
Ко.КонтекстПодбора.ИспользоватьРодителя(Родитель,0);
Ко.КонтекстПодбора.ИерархическийСписок(1,0);
//текущий элемент
Если Элемент.Выбран()=1 Тогда
Ко.КонтекстПодбора.АктивизироватьОбъект(Элемент);
КонецЕсли;
//заголовок
Если ПустаяСтрока(Заголовок)=0 Тогда
Ко.КонтекстПодбора.Форма.Заголовок(Заголовок,0);
КонецЕсли;
//отмена стандартной обработки
Возврат(0);
КонецФункции
Документы в 1С
Код //удаление ведущих нолей в номере документа
Функция гНомерДок(Зна чение) Экспорт
Текст=СокрЛП(Зна чение);
Текст=СтрЗаменить(Текст," ","");
Текст=СтрЗаменить(Текст,"_","-");
Если Константа.ФлагНомерОсн=0 Тогда
Возврат(Текст);
Ина чеЕсли Текст="0" Тогда
Возврат(Текст);
КонецЕсли;
//префикс
Префикс="";
Для i=1 По СтрЧислоВхождений(Текст,"-") Цикл
Позиция=Найти(Текст,"-");
Префикс=Префикс+Лев(Текст,Позиция);
Текст=Сред(Текст,Позиция+1);
КонецЦикла;
//удаление нолей
ФлагЧисло=0;
Номер="";
Для i=1 По СтрДлина (Текст) Цикл
Символ=Сред(Текст,i,1);
Если ЭтоЧисло(Символ)=0 Тогда
Номер=Номер+Символ;
Ина чеЕсли Не(Число(Символ)=0) Тогда
Номер=Номер+Символ;
ФлагЧисло=1;
Ина чеЕсли ФлагЧисло=1 Тогда
Номер=Номер+Символ;
КонецЕсли;
КонецЦикла;
//
Возврат(Префикс+Номер);
КонецФункции
//функция возвращает числовой номер документа без префикса
Функция гНомерБезПрефикса(Зна чение) Экспорт
Номер=гНомерДок(Зна чение);
Позиция=Найти(Зна чение,"-");
Номер=Сред(Номер,Позиция+1);
Возврат(Номер);
КонецФункции
//функция создаёт таблицу зна чений документов заданного вида по одному клиенту и даёт выбрать один документ
Функция гДокументКлиента(Зна чение,Клиент,ВидДокумента) Экспорт
Если Клиент.Выбран()=0 Тогда
Предупреждение("Не выбран Контрагент!");
Возврат(0);
КонецЕсли;
//таблица
М=СоздатьОбъект("ТаблицаЗна чений");
М.НоваяКолонка("Дата","Дата",,,,10);
М.НоваяКолонка("Док","Строка",,,"Документ",50);
М.НоваяКолонка("Сумма","Число",,,,18,"Ч015.2");
М.НоваяКолонка("Документ","Документ");
М.ВидимостьКолонки("Документ",0);
//документы
Д=СоздатьОбъект("Документ");
Д.ВыбратьПоЗна чению(,,"Клиент",Клиент);
Пока Д.ПолучитьДокумент()=1 Цикл
Состояние(""+Д.ДатаДок);
Если Не(Д.Вид()=ВидДокумента) Тогда
Продолжить;
КонецЕсли;
//
М.НоваяСтрока();
М.Документ=Д.ТекущийДокумент();
М.Дата=Д.ДатаДок;
М.Док=Д.ПредставлениеВида()+" "+СокрЛП(Д.НомерДок);
//сумма
Ж=Метаданные.Документ(Д.Вид());
Если Ж.РеквизитТабличнойЧасти("ВалСумма").Выбран()=1 Тогда
М.Сумма=Д.Итог("ВалСумма");
Ина чеЕсли Ж.РеквизитТабличнойЧасти("СуммаС").Выбран()=1 Тогда
М.Сумма=Д.Итог("СуммаС");
Ина чеЕсли Ж.РеквизитТабличнойЧасти("Сумма").Выбран()=1 Тогда
М.Сумма=Д.Итог("Сумма");
КонецЕсли;
КонецЦикла;
//проверка
Если М.КоличествоСтрок()=0 Тогда
Предупреждение("Документы не на йдены!");
Возврат(0);
КонецЕсли;
//строка по умолчанию
НомерСтр=0;
Если М.НайтиЗна чение(Зна чение,НомерСтр,"Документ")=0 Тогда
НомерСтр=М.КоличествоСтрок();
КонецЕсли;
//выбор
Заголовок=Метаданные.Документ(ВидДокумента).Представление()+": "+Клиент.Наименование;
Если М.ВыбратьСтроку(НомерСтр,Заголовок)=1 Тогда
Зна чение=М.ПолучитьЗна чение(НомерСтр,"Документ");
Возврат(1);
Ина че
Возврат(0);
КонецЕсли;
КонецФункции
Предопределённые функции и процедуры в 1С
Код Процедура ОбработкаЯчейкиТаблицы(Зна чение,Флаг,Таблица,Адрес)
Перем Ответ;
Перем Ко;
Если ПустоеЗна чение(Зна чение)=1 Тогда
Предупреждение("Невозможно обработать зна чение ячейки!");
Ина чеЕсли ТипЗна ченияСтр(Зна чение)="Документ" Тогда
Если гПользователь.ФлагСписок=0 Тогда
Флаг=1;
Ина че
А=СоздатьОбъект("СписокЗна чений");
А.ДобавитьЗна чение(0,"Открыть документ");
А.ДобавитьЗна чение(1,"Открыть в журна ле документов");
Если А.ВыбратьЗна чение(Ответ,,,,1)=1 Тогда
Если Ответ=0 Тогда
Флаг=1;
Ина че
Журна л=Метаданные.Документ(Зна чение.Вид()).Журна л.
Идентификатор;
ОткрытьФорму("Журна л."+Журна л+".Основна я",Ко);
Ко.АктивизироватьОбъект(Зна чение);
КонецЕсли;
КонецЕсли;
КонецЕсли;
Ина чеЕсли ТипЗна ченияСтр(Зна чение)="Справочник" Тогда
Если гПользователь.ФлагСписок=0 Тогда
Флаг=1;
Ина че
А=СоздатьОбъект("СписокЗна чений");
А.ДобавитьЗна чение(0,"Открыть элемент");
А.ДобавитьЗна чение(1,"Открыть в списке справочника");
Если А.ВыбратьЗна чение(Ответ,,,,1)=1 Тогда
Если Ответ=0 Тогда
Флаг=1;
Ина че
Журна л=Метаданные.Справочник(Зна чение.Вид()).Основна яФорма;
ОткрытьФорму("Справочник."+Зна чение.Вид()+"."+Журна л,Ко);
Ко.АктивизироватьОбъект(Зна чение);
КонецЕсли;
КонецЕсли;
КонецЕсли;
Ина чеЕсли ТипЗна ченияСтр(Зна чение)="СписокЗна чений" Тогда
//расшифровка - СписокЗна чений
Кнопка=Зна чение.Получить("Кнопка");
Если Число(Кнопка)=0 Тогда
Зна чение.СортироватьПоПредставлению();
//обработка - Ячейка
Представление="";
А=СоздатьОбъект("СписокЗна чений");
Для i=1 По Зна чение.РазмерСписка() Цикл
Отчет=Зна чение.ПолучитьЗна чение(i,Представление);
Если ПустаяСтрока(Отчет)=1 Тогда
Продолжить;
Ина чеЕсли Лев(Представление,4)="Меню" Тогда
//элемент контекстного меню в ячейке
Позиция=Найти(Отчет,"|");
Если Позиция=0 Тогда
Представление=Метаданные.Отчет(Отчет).Представление();
Ина че
Добавка=Сред(Отчет,Позиция+1);
Отчет=Лев(Отчет,Позиция-1);
Представление=Метаданные.Отчет(Отчет).Представление()+": "+Добавка;
КонецЕсли;
А.ДобавитьЗна чение(Отчет,Представление);
КонецЕсли;
КонецЦикла;
//контекстное меню в ячейке
Если А.РазмерСписка()>0 Тогда
Если А.ВыбратьЗна чение(Ответ,,,,1)=1 Тогда
Зна чение.Выгрузить(гПакет);
гПакет.Установить("Таблица","");
ОткрытьФормуМодально("Отчет."+Ответ,1+гПользователь.ФлагОтчет);
КонецЕсли;
КонецЕсли;
Ина че
//обработка - Кнопка
Зна чение.Выгрузить(гПакет);
гПакет.Установить("Таблица",Таблица);
Отчет=Зна чение.Получить("Отчет");
ОткрытьФормуМодально("Отчет."+Отчет,Кнопка);
гПакет.Установить("Таблица","");
КонецЕсли;
Ина чеЕсли ТипЗна ченияСтр(Зна чение)="Строка" Тогда
Если ВРег(Лев(СокрЛП(Зна чение),6))="ССЫЛКА" Тогда
СтрокаЗапуска=СокрЛП(Сред(Зна чение,7));
ЗапуститьПриложение(СтрокаЗапуска);
Ина че
Флаг=1;
КонецЕсли;
Ина че
//расшифровка - Стандартна я обработка ячейки
Флаг=1;
КонецЕсли;
КонецПроцедуры
Налоговый учёт и первое событие в 1С
Код
//функция определяет сумму первого события за период по заданным остаткам на на чало и конец периода
Функция гПервоеСобытие(НачД,НачК,КонД,КонК) Экспорт
//первое событие
СуммаД=Макс(КонД-НачД,0);
СуммаК=Макс(КонК-НачК,0);
//сумма
Возврат(СуммаД+СуммаК);
КонецФункции
Резюме
В статье описаны функции и процедуры, используемые в программе "1С:Предприятие 7.7" для работы со справочниками, документами, списками з
на чений, таблицами з
на чений и с прочими агрегатными типами данных. Образцы практического применения описанных средств Вы сможете
на йти в статьях "Отчёты для 1С" и "Обработки для 1С".
Источник публикации
Разместил: Андрей Громов | | Прочитано: 204930 | |