Вывод На Печать

  • Автор темы Freeland
  • Дата начала
F

Freeland

Гость
#1
Вечер добрый всем. Ситуация следующая имеется платформа 8.2, конфигурация Бухгалтерия базовая. Создал внешнюю обработку для создания договоров, все замечательно все работает, но есть одно но! Договор формируется из документа счет на оплату,когда он сформировался весь текст отлично отображается, когда захожу в предварительный просмотр вижу следующую картину:
Текст отображается корректно как я и хочу, перелистываю на следующую страницу, а она пустая, перелистываю следующую там текст который мне нужен, перелистываю на следующую опять пустой лист, перелистываю на 5-ю страницу текст который нужен, а на следующей опять пустота, в итоге вместо трех листов текста имею шесть на печати из которых 3 с нужным текстом и 3 пустых, подскажите куда копать?
Я предполагаю что возможно он берет из общих модулей то как надо выводить на печать но не чего не могу найти..:( может кто сталкивался и подскажет:)
 

Darlock

Well-Known Member
04.01.2008
560
1
Москва
#3
"И нечего так орать" (с) не помню кто сказал.

по сабжу - предположу, что макет - mxl, чередование текст/пустота - следствие того, что у вас на страницах текст выходит за края одласти печати на бумаге. Не сходите с ума, отформатируйте текст или используйте COM и соединяйтесь с Word'ом.
 

Дайнеко

Well-Known Member
19.11.2009
951
0
53
Минск
#4
Типичная проблема.
Надо в макете выделить и удалить все столбики (штук 100) правее последнего.
 

Darlock

Well-Known Member
04.01.2008
560
1
Москва
#5
Короче, из всего сказанного ранее - ищите на макете пунктирную вертикальную линию. И все колонки между нужным текстом и этой линии - удалить.
 
F

Freeland

Гость
#7
Вообщем отформатировал правую сторону и все стало на свои места, не подумал об этом, смутило что макет отображался корректно на первых листах.
 
F

Freeland

Гость
#8
Всем привет! Всех с праздниками прошедшими! Итак столкнулся с проблемой в справочнике Контрагенты, есть вкладка Контакты а там Физ лицо, суть в чем я хочу что бы при формировании договора бралось фио полностью в договор. Пока релизовал через строку, тупо сам ввожу.
Вот этим методом ФормированиеПечатныхФорм.ОписаниеОрганизации(УправлениеКонтактнойИнформацией.Све
денияОЮрФизЛице(Шапка.Получатель, Шапка.Дата), "ПолноеНаименование")
могу получить и наименование и инн , а вот как ФИО получить из контактов не где найти не могу, кто чем подскажет?
 

puh14

Well-Known Member
11.07.2008
1 412
0
НеРезиновая
#9
Поищи в общем модуле управление контактной информацией - там есть функция, которая тебе нужна. Подсказка - подписи в счетах-фактурах и товарняках используют ту-же функцию.
 
F

Freeland

Гость
#10
спасибо за подсказку ,но я там только вижу свои:

Руководители = ОбщегоНазначения.ОтветственныеЛица(Шапка.Руководители, Шапка.ДатаДокумента, ПодразделениеОтветственныхЛиц);

ОбластьМакетаПодвал.Параметры.ФИОРуководителя = Руководители.РуководительПредставление;
ОбластьМакетаПодвал.Параметры.ФИОГлавБухгалтера = Руководители.ГлавныйБухгалтерПредставление;
ОбластьМакетаПодвал.Параметры.ДолжностьРуководителя = Руководители.РуководительДолжность;
а, мне нужны данные конкретного контрагента ,у которого фио стоит основным.
 

puh14

Well-Known Member
11.07.2008
1 412
0
НеРезиновая
#11
вот как ФИО получить из контактов
а, мне нужны данные конкретного контрагента ,у которого фио стоит основным.
так всё-таки ФИО или контрагента?

Можно например так

ОбщегоНазначения.ПолучитьКонтактноеЛицоКонтрагентаПоДолжности (Документ.Клиент,Справочники.РолиКонтактныхЛиц.Руководитель) Это вернет тебе ссылку на контактное лицо.
внутри контактного лица контрагента есть ссылка на реквизит с именем контактноеЛицо и типом справочникссылка.контактныеЛица - в нем есть наименование, которое ты в принципе можешь использовать, и есть поля Фамилия, Имя, Отчество.

Если тебе надо узнать в каких контрагентах данный товарисч участвует как основной тогда так

выбрать Различные Спр.Владелец из Справочники.КонтактныеЛицаКонтрагентов как Спр Где Спр.КонтактноеЛицо = &КонтактноеЛицо и Спр.Владелец.ОсновноеКонтактноеЛицо = Спр.Ссылка;

&КонтактноеЛицо - параметр с типом справочникСсылка.КонтактныеЛица
 
F

Freeland

Гость
#12
Смотри получилось таким образом : СсылкаНаОбъект.Контрагент.ОсновноеКонтактноеЛицо;
только вот можно реализовать что бы в В одном месте было записно в Род. Падеже, а в другом инициалами в именительном. Спасибо за помощь!
 
F

Freeland

Гость
#13
а вообще я сделал вот таким образом
ДанныеФЛ = СсылкаНаОбъект.Контрагент.ОсновноеКонтактноеЛицо;
ОбластьМакета.Параметры.ЗаказчикФИО =ДанныеФЛ.Фамилия + " " + ДанныеФЛ.Имя ;
И вот тут я думаю можно как нибудь задать параметр , что бы Имя и Отчество выводились только первые буквы..
 

Darlock

Well-Known Member
04.01.2008
560
1
Москва
#14
Используйте функцию "Лев(параметр1, Параметр2)"
Параметр1 - строка, которую режим
Параметр2 - стколько символов отрезаем.

Лев (Left)
Синтаксис:
Лев(<Строка>, <Число символов>)
Параметры:
<Строка> (обязательный)
Тип: Строка. Исходная строка.
<Число символов> (обязательный)
Тип: Число. Количество выбираемых символов.
Возвращаемое значение:
Тип: Строка. Строка выбранных символов.
Описание:
Выбирает первые слева символы строки.
Пример:
ИнициалИмени = Лев(Сотрудник.Имя, 1);
ИнициалОтчества = Лев(Сотрудник.Отчество, 1);
ПолноеИмя = Сотрудник.Фамилия+" "+ИнициалИмени+"."+ИнициалОтчества+".";

P.S. а вообще, люди поговаривают, что синтакс-помощник помогает.
 
F

Freeland

Гость
#15
Синтакс -помощник и вправду помогает:)! Спасибо с инициалами все получилось, вот склонять фамилию и имя , существуют ли какие то универсальные обработки встроенные в базовую конфигурацию.?
 

Darlock

Well-Known Member
04.01.2008
560
1
Москва
#16
Нет, в платформе такого нет. Есть специальные ВК для склонения. Можно заморочиться и написать код на 1С, только исключений у вас может быть вагон и маленькая тележка. Исключения - не склоняемые имена, фамилии отчетсва, сложные отчества (..оглы) и т.п.
ВК для склонения тут


Просклонять(ФИО, Падеж, Пол)

Параметр ФИО должен содержать фамилию, имя и отчество в именительном падеже единственного числа. Строка должна состоять из букв русского алфавита, пробелов и дефисов. Фамилия, имя и отчество должны разделяться пробелами. Двойные и тройные имена и фамилии должны писаться через дефис. Имена и отчества должны быть полными.

Параметр Падеж - задается числом и может принимать следующие значения от 1 до 6. (1 Именительный, 2 - Родительный, 3 - Дательный, 4 - Винительный, 5 - Творительный, 6 - Предложный)

Параметр Пол является не обязательным и принимает значения: 0 - авто, 1 - мужской, 2 - женский.

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

<div class="sp-wrap"><div class="sp-head-wrap"><div class="sp-head folded clickable">Пример</div></div><div class="sp-body"><div class="sp-content">
Код:
Попытка

// Загружаем внешнюю компоненту
ЗагрузитьВнешнююКомпоненту("NameDecl.dll");
Объект = Новый("AddIn.NameDeclension");

Исключение

Сообщить("Ошибка загрузки внешней компоненты для склонения ФИО! Функции склонения будут недоступны!" + ОписаниеОшибки());

КонецПопытки;

// Определяем ФИО, которые надо просклонять
ФИО = " Сидоров Иван Иванович";

// Задаем требуемый падеж
Падеж = 3;

// Получаем результат склонения
Результат = Объект.Просклонять(ФИО, Падеж);
 
F

Freeland

Гость
#17
Спасибо, можно обращаться на ты:), буду побывать.
 

Дайнеко

Well-Known Member
19.11.2009
951
0
53
Минск
#18
вот склонять фамилию и имя , существуют ли какие то универсальные обработки встроенные в базовую конфигурацию.?
Будьте прощее и на жизнь смотрите легше. Создай реквизит строчный "ФИОвРодительномПадеже". Кнопочкой программа запоняет фразу "Директора Петров В.В" а человек правит. При печати вставляем в после слов "в лице".
 
F

Freeland

Гость
#19
Вообще у меня все так и реализовано:facepalm: Хотел Автоматизировать больше.