|
|||
DaryaKoroleva
28.06.13 — 14:03 |
Делаю внешнюю печатную форму. Добавила область «Приказ». |
||
ДенисЧ
1 — 28.06.13 — 14:04 |
Наверное, нет такой области… |
||
1Cv8_accepted
2 — 28.06.13 — 14:05 |
ОбластьМакета = ПолучитьМакет(«ИмяТвоегоМакета»).ПолучитьОбласть(«Приказ»); |
||
1Cv8_accepted
3 — 28.06.13 — 14:07 |
(0) Кстати, область, надеюсь, которая красными линиями выделяется (Ctrl+Shift+N), а не именованая область ячеек в табличном документе? |
||
DaryaKoroleva
4 — 28.06.13 — 14:09 |
(1) Есть =) |
||
Cyberhawk
5 — 28.06.13 — 14:11 |
Без фото в профиле метод ПолучитьОбласть() работать не будет |
||
ДенисЧ
6 — 28.06.13 — 14:11 |
(4) Не верю (с) |
||
DaryaKoroleva
7 — 28.06.13 — 14:19 |
http://s5.uploads.ru/uvGzH.png |
||
ДенисЧ
8 — 28.06.13 — 14:22 |
Ерундистика какая-то. |
||
User_Agronom
9 — 28.06.13 — 14:25 |
А все остальные область нормально получаются? |
||
pessok
10 — 28.06.13 — 14:25 |
а нафига в отдельную область выносить константу? моар кода? |
||
User_Agronom
11 — 28.06.13 — 14:26 |
+ (9) области |
||
pessok
12 — 28.06.13 — 14:27 |
а по делу — может не тот макет? например, пытаешься получить общий макет ТОРГ-12, в котором нет этой области? |
||
DaryaKoroleva
13 — 28.06.13 — 14:33 |
Все исправила!) И по этому, как бы я не меняла макет, который был добавлен в обработку, на печать выводился общий, в котором нет моих изменений) Блин))) |
||
DaryaKoroleva
14 — 28.06.13 — 14:34 |
(12) Ну да) |
||
DaryaKoroleva
15 — 28.06.13 — 14:34 |
Спасибо) |
||
Mitriy 16 — 28.06.13 — 14:35 |
гы… |
TurboConf — расширение возможностей Конфигуратора 1С
|
|||
DaryaKoroleva
28.06.13 — 14:03 |
Делаю внешнюю печатную форму. Добавила область «Приказ». Но вылезает ошибка: «Ошибка при вызове метода контекста (ПолучитьОбласть): Область не найдена: » Вывожу ее кодом: ОбластьМакета = Макет.ПолучитьОбласть(«Приказ»); ТабДокумент.Вывести(ОбластьМакета); |
||
ДенисЧ
1 — 28.06.13 — 14:04 |
Наверное, нет такой области… |
||
1Cv8_accepted
2 — 28.06.13 — 14:05 |
ОбластьМакета = ПолучитьМакет(«ИмяТвоегоМакета»).ПолучитьОбласть(«Приказ»); |
||
1Cv8_accepted
3 — 28.06.13 — 14:07 |
(0) Кстати, область, надеюсь, которая красными линиями выделяется (Ctrl+Shift+N), а не именованая область ячеек в табличном документе? |
||
DaryaKoroleva
4 — 28.06.13 — 14:09 |
(1) Есть =) (3) Красными-красными =) |
||
Cyberhawk
5 — 28.06.13 — 14:11 |
Без фото в профиле метод ПолучитьОбласть() работать не будет |
||
ДенисЧ
6 — 28.06.13 — 14:11 |
(4) Не верю (с) Скриншоты в студию |
||
DaryaKoroleva
7 — 28.06.13 — 14:19 |
http://s5.uploads.ru/uvGzH.png |
||
ДенисЧ
8 — 28.06.13 — 14:22 |
Ерундистика какая-то. Может, макет не тот правишь.. А может (5) прав… |
||
User_Agronom
9 — 28.06.13 — 14:25 |
А все остальные область нормально получаются? |
||
pessok
10 — 28.06.13 — 14:25 |
а нафига в отдельную область выносить константу? моар кода? |
||
User_Agronom
11 — 28.06.13 — 14:26 |
+ (9) области |
||
pessok
12 — 28.06.13 — 14:27 |
а по делу — может не тот макет? например, пытаешься получить общий макет ТОРГ-12, в котором нет этой области? |
||
DaryaKoroleva
13 — 28.06.13 — 14:33 |
Все исправила!) Дошло в чем дело =) Надо было заменить сточку: Макет = ПолучитьОбщийМакет(«ТОРГ12»); На: Макет = ПолучитьМакет(«ТОРГ12»); И по этому, как бы я не меняла макет, который был добавлен в обработку, на печать выводился общий, в котором нет моих изменений) Блин))) |
||
DaryaKoroleva
14 — 28.06.13 — 14:34 |
(12) Ну да) |
||
DaryaKoroleva
15 — 28.06.13 — 14:34 |
Спасибо) |
||
Mitriy 16 — 28.06.13 — 14:35 |
гы… |
TurboConf — расширение возможностей Конфигуратора 1С |
ВНИМАНИЕ! Если вы потеряли окно ввода сообщения, нажмите Ctrl-F5 или Ctrl-R или кнопку «Обновить» в браузере.
Тема не обновлялась длительное время, и была помечена как архивная. Добавление сообщений невозможно.
Но вы можете создать новую ветку и вам обязательно ответят!
Каждый час на Волшебном форуме бывает более 2000 человек.
Автор romanprogrammist, 29 ноя 2013, 21:30
0 Пользователей и 1 гость просматривают эту тему.
Ошибка при вызове метода контекста (ПолучитьОбласть): Область не найдена: НомерСтроки
Сам текст:
Если Тип = "Счет" Тогда
ОбластьМакета = Макет.ПолучитьОбласть("ЗаголовокСчета");
ОбластьМакета.Параметры.Заполнить(ПараметрыПечати);
ТабДокумент.Вывести(ОбластьМакета);
КонецЕсли;
ОбластьМакета = Макет.ПолучитьОбласть("Заголовок");
ОбластьМакета.Параметры.Заполнить(ПараметрыПечати);
ТабДокумент.Вывести(ОбластьМакета);
ОбластьМакета = Макет.ПолучитьОбласть("Поставщик");
ОбластьМакета.Параметры.Заполнить(ПараметрыПечати);
ТабДокумент.Вывести(ОбластьМакета);
ОбластьМакета = Макет.ПолучитьОбласть("Покупатель");
ОбластьМакета.Параметры.Заполнить(ПараметрыПечати);
ТабДокумент.Вывести(ОбластьМакета);
ОбластьНомера = Макет.ПолучитьОбласть("ШапкаТаблицы|НомерСтроки");
ОбластьКодов = Макет.ПолучитьОбласть("ШапкаТаблицы|КолонкаКодов");
ОбластьДанных = Макет.ПолучитьОбласть("ШапкаТаблицы|Данные");
ОбластьСкидок = Макет.ПолучитьОбласть("ШапкаТаблицы|Скидка");
ОбластьСуммы = Макет.ПолучитьОбласть("ШапкаТаблицы|Сумма");
и тд
макет свой
В твоем макете отсутствует область «НомерСтроки» или названа по-другому.
Правильно ведите учет или пишите программы и вам воздастся!…
(Кстати — кнопочку Сказать Спасибо — никто не отменял)
- Форум 1С
- ►
Форум 1С — ПРЕДПРИЯТИЕ 8.0 8.1 8.2 8.3 8.4 - ►
Конфигурирование, программирование в 1С Предприятие 8 - ►
Счет для УТ 10.3: Ошибка при вызове метода контекста (ПолучитьОбласть)
Похожие темы (5)
Поиск
В платформе 1С сообщения об ошибках бывают достаточно запутаны, и без должных навыков разобраться в причинах достаточно сложно. Вот и сообщение об ошибке при вызове контекста может ввести в ступор начинающего разработчика. Однако в подавляющем большинстве случаев мы видим подобное сообщение, если разработчик допустил ошибку в своем коде. Причем речь зачастую идет не об орфографических ошибках, а о логических.
Исправляем ситуацию
Чтобы избавиться от этого неприятного сообщения об ошибке при вызове метода контекста, следует понимать, что контекстом называют методы платформы 1С. Значит в определенной строке кода воспользовались методом с неверными параметрами или вызвали его не от того владельца. Всегда внимательно и полностью читайте сообщения об ошибках – часто в них содержится указание на строку и метод, вызвавший ошибку. Это поможет сэкономить время на отладку и поиск проблемного места в коде.
Рассмотрим действия разработчика на примере со специально допущенной ошибкой. Мы запускаем на исполнение нижеприведенный кусок кода с запросом, в котором забыли дописать условие отбора. Компилятор 1С пропускает такую процедуру, так как орфографических ошибок в написании команд мы не допустили. Однако в режиме предприятия нас ждет такое сообщение об ошибке:
Запрос = Новый Запрос;
Запрос.Текст =
"ВЫБРАТЬ
| Номенклатура.Ссылка КАК Ссылка,
| Номенклатура.ВерсияДанных КАК ВерсияДанных,
| Номенклатура.ПометкаУдаления КАК ПометкаУдаления,
| Номенклатура.Родитель КАК Родитель,
| Номенклатура.ЭтоГруппа КАК ЭтоГруппа,
| Номенклатура.Код КАК Код,
| Номенклатура.Наименование КАК Наименование,
| Номенклатура.Артикул КАК Артикул,
| Номенклатура.ЕдиницаИзмерения КАК ЕдиницаИзмерения,
| Номенклатура.ТипНоменклатуры КАК ТипНоменклатуры,
| Номенклатура.Предопределенный КАК Предопределенный,
| Номенклатура.ИмяПредопределенныхДанных КАК ИмяПредопределенныхДанных
|ИЗ
| Справочник.Номенклатура КАК Номенклатура
|ГДЕ
| ";
РезультатЗапроса = Запрос.Выполнить();
ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать();
Пока ВыборкаДетальныеЗаписи.Следующий() Цикл
КонецЦикла;
Приведенный текст ошибки программисту 1С скажет, что в модуле формы обработки «ЧтениеЗаписьXML на 152 строчке кода не может выполниться запрос. Причина в том, что на 17 строчке запроса нет чего-то, что ждал компилятор. Таким образом, чтобы убрать подобное сообщение, необходимо выяснить, что там должно быть и написать недостающий код.
Увидев вышеприведенный кусок кода, разработчик заметит, что в запросе есть служебное слово «ГДЕ», дающее сигнал 1С, что дальше будет условие. Но мы забыли дописать его и, естественно, система с помощью сообщения об ошибке спрашивает нас – «а где условие?». Чтобы исправить эту ситуацию необходимо либо убрать оператор «ГДЕ» из запроса, либо добавить условие.
Но ошибки могут быть не только в текстах запросов. Допустим, мы хотим выбрать всю номенклатуру и узнать, входит ли она в определенную группу. Проверка происходит с помощью метода «ПринадлежитЭлементу» и его параметра, который должен быть типа СправочникСсылка. Мы опять допускаем ошибку и вместо ссылки в параметр метода помещаем строку, содержащую имя переменной.
Запрос = Новый Запрос;
Запрос.Текст =
"ВЫБРАТЬ
| Номенклатура.Ссылка КАК Ссылка,
| Номенклатура.ВерсияДанных КАК ВерсияДанных,
| Номенклатура.ПометкаУдаления КАК ПометкаУдаления,
| Номенклатура.Родитель КАК Родитель,
| Номенклатура.ЭтоГруппа КАК ЭтоГруппа,
| Номенклатура.Код КАК Код,
| Номенклатура.Наименование КАК Наименование,
| Номенклатура.Артикул КАК Артикул,
| Номенклатура.ЕдиницаИзмерения КАК ЕдиницаИзмерения,
| Номенклатура.ТипНоменклатуры КАК ТипНоменклатуры,
| Номенклатура.Предопределенный КАК Предопределенный,
| Номенклатура.ИмяПредопределенныхДанных КАК ИмяПредопределенныхДанных
|ИЗ
| Справочник.Номенклатура КАК Номенклатура
|ГДЕ
| НЕ Номенклатура.ЭтоГруппа ";
НужнаяГруппаЭлементов = Справочники.Номенклатура.НайтиПоНаименованию("Мебель");
РезультатЗапроса = Запрос.Выполнить();
ВыборкаДетальныеЗаписи = РезультатЗапроса.Выбрать();
Пока ВыборкаДетальныеЗаписи.Следующий() Цикл
Сообщить(ВыборкаДетальныеЗаписи.Ссылка.ПринадлежитЭлементу("НужнаяГруппаЭлементов"));
КонецЦикла;
1С выдает настолько же информативное сообщение, из которого мы понимаем, что на 158 строке у 1 параметра неправильный тип. Но что же делать, если мы не знаем, какой тип должен быть? В этом нам поможет Синтакс-помощник, встроенный в платформу 1С.
В конфигураторе находим строку и метод, на который указывало сообщение об ошибке, и нажимаем на него правой кнопкой мыши. Выбираем пункт «Поиск в синтакс-помощнике» и платформа самостоятельно ищет справочную информацию по выделенному методу. В справке мы видим не только подробное описание параметров и самого метода, но и пример. Сверив пример с нашим кодом, приходит понимание, что кавычки не нужны и без них все работает.
Чаще всего причиной подобных ошибок выступают следующие факторы:
- Невнимательность;
- Отсутствие опыта или знаний;
- Несогласованность действий разработчиков друг с другом;
- Изменения в методах контекста в новых версиях платформы.
Но ошибки при разработке ПО случаются постоянно, поскольку иногда ошибаются даже специалисты с многолетним опытом. Самое главное – уметь исправлять их и учиться на них. Постепенно вы будете видеть сообщения об ошибках все реже и научитесь замечать подобные «опечатки» еще до запуска 1С.
|
Здравствуйте. В 1С не печатает или где? |
sucharik 0 / 0 / 0 Регистрация: 23.08.2011 Сообщений: 134 |
||||
1 |
||||
1C 8.x Ошибка в коде27.09.2011, 09:57. Показов 5505. Ответов 6 Метки нет (Все метки)
подскажите пожалуйста вот код
запускаю выдаёт ошибку заранее спасибо
0 |
31 / 31 / 0 Регистрация: 19.03.2011 Сообщений: 100 |
|
27.09.2011, 11:20 |
2 |
Попробуйте так:
Процедура Печать1(ТабДок, Ссылка) Экспорт Шапка = Макет.ПолучитьОбласть(Шапка); ВставлятьРазделительСтраниц = Ложь; ТабДок.Вывести(ОбластьТабличнаяЧасть3Шапка); Пока ВыборкаТабличнаяЧасть3.Следующий() Цикл ВставлятьРазделительСтраниц = Истина;
0 |
308 / 308 / 1 Регистрация: 16.01.2011 Сообщений: 1,073 |
|
27.09.2011, 11:29 |
3 |
Попробуйте так: только соединить две таблицы нужно левым соединением
0 |
31 / 31 / 0 Регистрация: 19.03.2011 Сообщений: 100 |
|
27.09.2011, 11:36 |
4 |
только соединить две таблицы нужно левым соединением Тьфу, забыл совсем. Спасибо за дополнение.
0 |
0 / 0 / 0 Регистрация: 23.08.2011 Сообщений: 134 |
|
27.09.2011, 11:41 [ТС] |
5 |
Попробуйте так: {Документ.СправкаКЗаказу.МодульМенеджера(119)}: Ошибка при вызове метода контекста (Выполнить): {(7, 4)}: Неправильный псевдоним «ТабличнаяЧасть3.НаименованиеРабот» Неправильный Псевдоним
0 |
31 / 31 / 0 Регистрация: 19.03.2011 Сообщений: 100 |
|
27.09.2011, 11:56 |
6 |
Хм, в Конфигураторе проверьте название ТЧ документа и попробуйте по-другому назвать представление.
0 |
0 / 0 / 0 Регистрация: 23.08.2011 Сообщений: 134 |
|
27.09.2011, 12:08 [ТС] |
7 |
Хм, в Конфигураторе проверьте название ТЧ документа и попробуйте по-другому назвать представление. не чего не помогает(((( Добавлено через 4 минуты
не чего не помогает(((( спасибо за помощь,но там всё просто.Запятую забыл поставить)))))
0 |
IT_Exp Эксперт 87844 / 49110 / 22898 Регистрация: 17.06.2006 Сообщений: 92,604 |
27.09.2011, 12:08 |
7 |