Отправка почты с использованием основного почтового клиента ОС

21.09.11

Разработка - Универсальные функции

В публикации описан фрагмент кода, позволяющий отправлять печатные формы с помощью почтового клиента операционной системы (напр. Outlook, Bat и т.д.)

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

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

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

  2. Добавить общий модуль "_управлениеПочтой" (см. рис2), в него скопировать процедуры: "ОтправитьПечатнуюФормуВнешнимТранспортом" и "КорректировкаНаименования" (ниже приведены см. п. 4).

  3. В общем модуле "УправлениеОтчетами" отредактировать процедуру "ОтправитьДокументПоЭлектроннойПочте", закомментировав сообщение и добавив вызов нашей процедуры "ОтправитьПечатнуюФормуВнешнимТранспортом". Редактируемый фрагмент этой процедуры:

	 Если НЕ Константы.ИспользованиеВстроенногоПочтовогоКлиента.Получить() Тогда
    //ОбщегоНазначения.СообщитьОбОшибке("Отправлять документы по электронной почте можно только из встроенного почтового клиента.
    // |В настоящее время в настройках параметров учета установлено использование основного почтового клиента операционной системы.");
    //Предупреждение("Операция не выполнена");
    _управлениеПочтой.ОтправитьПечатнуюФормуВнешнимТранспортом (Документ, УправлениеПользователями.ПолучитьЗначениеПоУмолчанию     (ПараметрыСеанса.ТекущийПользователь,"ОсновнойКаталогФайлов"),ИмяФайлаВложения); // изменения программиста начало
    Возврат;
КонецЕсли;

     4. Текст модуля  _управлениеПочтой:
 
Процедура ОтправитьПечатнуюФормуВнешнимТранспортом (ПолеТабличногоДокумента, КаталогФормирования="",имяФайлаВложения) Экспорт

    Расширение="xls";

    Файл = Новый Файл(КаталогФормирования);
    Если Файл.Существует() Тогда
        ИмяФайла = КаталогФормирования;
    Иначе
        ИмяФайла = КаталогВременныхФайлов();
    КонецЕсли;

    Если Не ПустаяСтрока(ИмяФайла) Тогда
        Если Не Прав(ИмяФайла, 1) = "\" Тогда
            ИмяФайла = ИмяФайла + "\";
        КонецЕсли;
    КонецЕсли;

    ОтносительноеИмя =КорректировкаНаименования(имяФайлаВложения, ложь);
    ИмяФайлаБезРасширения = ИмяФайла + ОтносительноеИмя;

    ИмяФайла = ИмяФайлаБезРасширения + ".xls";
    ПолеТабличногоДокумента.Записать(ИмяФайла, ТипФайлаТабличногоДокумента.XLS97);

    Почта=Новый Почта;
    Почта.Подключиться();
    Сообщ=Новый ПочтовоеСообщение;
    Сообщ.Тема=имяФайлаВложения;
    Сообщ.Текст="";
    ВыбФайл=Новый Файл(ИмяФайла);
    Если ВыбФайл.Существует() Тогда
        Данные=Новый ДвоичныеДанные(ИмяФайла);
        Сообщ.Вложения.Добавить(Данные,ВыбФайл.Имя);
    КонецЕсли;
    //УчетнаяЗапись=УправлениеПользователями.ПолучитьЗначениеПоУмолчанию(ПараметрыСеанса.ТекущийПользователь,"ОсновнаяУчетнаяЗапись");
    //Сообщ.Получатели.Добавить(УчетнаяЗапись.АдресЭлектроннойПочты);
    Почта.Послать(Сообщ,);
    Почта.Отключиться();

    Попытка
        УдалитьФайлы(ИмяФайла);
        //Сообщить("Удален файл "+ИмяФайла);
    Исключение
        Сообщить(ОписаниеОшибки());
    КонецПопытки;

КонецПроцедуры


Функция КорректировкаНаименования(Знач ИсходнаяСтрока, Выводитьсообщения=Истина)

    Наименование=СокрЛП(ИсходнаяСтрока);
    ДлиннаНаим=СтрДлина(Наименование);
    СписокЗаменяемыхимволов=новый СписокЗначений;

    Если ДлиннаНаим=0 Тогда
        Сообщение="Не заполнена проверяемая строка!";
        #Если Клиент Тогда
            Если Выводитьсообщения Тогда
                Сообщить(Сообщение);
            КонецЕсли;
        #КонецЕсли
    КонецЕсли;

    Для i=0 По ДлиннаНаим-1 Цикл  
        Стр=Прав(Наименование,ДлиннаНаим-i);  
        // руск. алф. 192- 255 англ. алф. мал. 65-90 англ. алф. бол. 97-122 пробел=32 цифры АSCI дес.
        Если (((КодСимвола(Стр)>1039) И (КодСимвола(Стр)<1106)) ИЛИ ((КодСимвола(Стр)>64) И (КодСимвола(Стр)<94)) ИЛИ ((КодСимвола(Стр)>96) И (КодСимвола(Стр)<123)) ИЛИ ((КодСимвола(Стр)>47) И (КодСимвола(Стр)<58)) И (КодСимвола(Стр)<>32)) Тогда
        Иначе
            СписокЗаменяемыхимволов.Добавить(Лев(Стр,1));
        КонецЕсли;
    КонецЦикла;

  Для каждого ЭлементСписка Из СписокЗаменяемыхимволов Цикл
      Если ЭлементСписка.Значение=" " Тогда
          Наименование=СтрЗаменить(Наименование,ЭлементСписка.Значение,"_");
          Сообщение="В наименование колонки "+ИсходнаяСтрока+" встречается недопустимый символ (пробел) "+ЭлементСписка.Значение+", он будет заменен на '_'";
          #Если Клиент Тогда
              Если Выводитьсообщения Тогда
                  Сообщить(Сообщение);
              КонецЕсли;
          #КонецЕсли
      Иначе
          Наименование=СтрЗаменить(Наименование,ЭлементСписка.Значение,"");
          Сообщение="В наименование колонки "+ИсходнаяСтрока+" встречается недопустимый символ "+ЭлементСписка.Значение+", он будет удален";
          #Если Клиент Тогда
              Если Выводитьсообщения Тогда
                  Сообщить(Сообщение);
              КонецЕсли;
          #КонецЕсли  
        КонецЕсли
    КонецЦикла;
    Возврат Наименование;
КонецФункции

См. также

Взаиморасчеты Email рассылки Акт сверки Бухгалтер Пользователь Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бухгалтерский учет Платные (руб)

Внешняя обработка для Бухгалтерии 3.0 - позволяет автоматически формировать документы «Акт сверки расчетов» с контрагентами за выбранный период с последующей фоновой отправкой на почту контрагента.

3000 руб.

25.11.2020    24495    238    8    

205

SALE! 20%

Email рассылки Программист Пользователь Платформа 1С v8.3 Конфигурации 1cv8 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Платные (руб)

Решение для массовой рассылки печатных форм (в том числе и дополнительных) любых документов, и произвольных файлов. Рассылка возможна посредством электронной почты, Telegram и файловой системы. Рассылка пакета документов. Добавление факсимильных печати и подписи. Произвольные шаблоны HTML/Simple text с автозаполнением любыми полями документа. Любые форматы файлов. Упаковка вложений в архив. Транслитерация имен файлов. Разбиение рассылки на произвольные порции. Обход спам-фильтров. Журналирование рассылок.

4920 3936 руб.

30.06.2022    11024    72    98    

34

Загрузка и выгрузка в Excel Монитор заказов Email рассылки Пользователь Бухгалтерский учет 8.3.14 1С:Бухгалтерия 3.0 Россия Управленческий учет Платные (руб)

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

6000 руб.

13.10.2021    10128    3    0    

3

Взаиморасчеты Email рассылки Бухгалтер Пользователь Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бухгалтерский учет Платные (руб)

Обработка позволяет автоматически сформировать акты сверок на почту контрагентов (почта берется из контактных данных контрагента). При формировании акта сверки формируется подпись с указанием контактов для связи с бухгалтерией нашей организации (формируется исходя из контактов из карточки организации). Присутствует возможность ручного редактирования электронной почты контрагента для отправки. Отправка осуществляется с системной записи электронной почты. В случае, если у контрагента нет адреса электронной почты, эти контрагенты будут выведены в отдельной табличной части. Это очень удобно, так как сразу наглядно виден список контрагентов, которым невозможно отправить акты сверок!

7080 руб.

11.05.2021    9468    6    1    

6
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
0. Администратор 1С 41 22.09.11 05:08 Сейчас в теме
В публикации описан фрагмент кода, позволяющий отправлять печатные формы с помощью почтового клиента операционной системы (напр. Outlook, Bat и т.д.)

Перейти к публикации

1. Angeros 22.09.11 05:08 Сейчас в теме
Спс. Идея обязательно пригодиться.
2. sstar90 22.09.11 12:21 Сейчас в теме
Спасибо за идею, попробуем
3. CheBurator 2712 22.09.11 21:05 Сейчас в теме
как в снеговике это с извращениями сделано...
открой для себя
1. встроенный в винды штатный транспорт отправки писем CDO
.
на 7.7 в любой конфигурации для ЛЮБОГО отчета достаточно всего одной обработки
http://infostart.ru/public/14180/
http://infostart.ru/public/14131/
4. Администратор 1С 41 22.09.11 21:24 Сейчас в теме
(3) CheBurator,
О CDO знаю, твои обработки конечно хороши, но есть недостаток - письмо отправленное через CDO не сохранится в корпоративной почте в папке исходящие.
5. Администратор 1С 41 22.09.11 21:29 Сейчас в теме
(3) а этот момент иногда является принципиальным
6. Kazan 12.10.11 05:21 Сейчас в теме
Не проходит авторизацию пока ручками не откроешь клиент. win live mail 2011
7. plevako 12.10.11 14:48 Сейчас в теме
8. MYRZILKA123 2 21.10.11 16:25 Сейчас в теме
спасибо попробовал теперь пользуюсь.
9. Sanek_159 1 11.05.12 15:12 Сейчас в теме
Здравствуйте!
Конфигурация УПП 1.3.25
Когда делаю отправку из 1C появляется окно с сообщением: "С запрошенным действием не связана программа электронной почты.Установите программу электронной почты или,если она уже установлена,создайте связь в панели управления "Программы по умолчанию""
Если вхожу в Панель управления-Программы по умолчанию там всегда выбрана конфигурация Другая. Редактирую ее-выставляю Mozilla Thunderbird как почтовую программу по умолчанию, жму ОК. Перезахожу-все остается на своих местах. Если выбираю другую конфигурацию(Microsoft Windows или Не Microsoft) то все равно активной остается конфигурация Другая.
PS: пробовал с другого ПК где установлен outlook 2010, ничего не происходит и ошибка не вываливается. Подскажите, пожалуйста, что может быть не так?
10. Администратор 1С 41 12.05.12 19:01 Сейчас в теме
Я не силен в настройках ОС, а я так понимаю дело именно в них. Код рабочий. У вас работает пункт меню Windows "отправить->адресат", вызываемый по щелчку правой кнопки мыши на любом файле?
Вот что яндекс говорит, может поможет: "http://forum.windowsfaq.ru/showthread.php?t=91294"
11. haous 2 03.10.12 16:19 Сейчас в теме
А для УТП для Украины 8.2 подойдет?
12. Администратор 1С 41 05.10.12 16:48 Сейчас в теме
Попробуйте,
скорее всего да
13. BlackStar 19.12.12 17:00 Сейчас в теме
А с MS Outlook работает у кого нибудь? У меня при нажатии на отправку на секунду часы появляются, и больше ничего, почтовый клиент не открывается. При этом пункт меню Windows "отправить->адресат" работает нормально
16. Sanek_159 1 29.08.13 11:00 Сейчас в теме
(13) BlackStar, Тоже не открывается (Outlook 2010), часы на секунду и все. Удалось решить кому проблему?
При использовании программы по умолчанию Mozilla Thunderbird открывается только программа, но не создается новое письмо, в чем может быть проблема?
14. isn 15 22.05.13 10:04 Сейчас в теме
Здравствуйте!
Вы можете в пункте 3 опубликовать всю процедуру которая в итоге должна появится?
15. Администратор 1С 41 22.05.13 19:04 Сейчас в теме
(14) isn,

В моем релизе (10.3.10.14) она с учетом моих правок выглядит так:

Процедура ОтправитьДокументПоЭлектроннойПочте(Документ, ИмяФайлаВложения = "") Экспорт

Если НЕ Константы.ИспользованиеВстроенногоПочтовогоКлиента.Получить() Тогда
//ОбщегоНазначения.СообщитьОбОшибке("Отправлять документы по электронной почте можно только из встроенного почтового клиента.
// |В настоящее время в настройках параметров учета установлено использование основного почтового клиента операционной системы.");
//Предупреждение("Операция не выполнена");
_управлениеПочтой.ОтправитьПечатнуюФормуВнешнимТранспортом (Документ, УправлениеПользователями.ПолучитьЗначениеПоУмолчанию(ПараметрыСеанса.ТекущийПользователь,"ОсновнойКаталогФайлов"),ИмяФайлаВложения); //изменения программиста
Возврат;
КонецЕсли;

ФормаОтправкиДокумента = ПолучитьОбщуюФорму("НастройкаОтправкиОтчета");
ФормаОтправкиДокумента.Отчет = Документ;
ФормаОтправкиДокумента.ИмяФайлаВложения = СтрЗаменить(ИмяФайлаВложения, ".", " ");
ФормаОтправкиДокумента.ТемаСообщения = ИмяФайлаВложения;
ФормаОтправкиДокумента.ОткрытьМодально();

КонецПроцедуры
17. AHuk 04.09.13 18:22 Сейчас в теме
Спасибо огромное. Но есть вопрос, как передать тему и текст и получателя - это ясно, но можно ли передать текст в HTML коде? и у меня вложения в виде "v8_C56_7a.tmp" формируется, в чём может быть проблема?
Прикрепленные файлы:
19. Программулькин 301 23.03.17 13:38 Сейчас в теме
Сначала хотел плюсануть, НО затем решил попробовать. Захотелось поставить минус, ибо не заработало, НО минусовать не буду. Насколько я понял, смысл статьи показать на примере использования функции глобального контекста: Почта (Mail)
Методы:
Выбрать (Get)
Отключиться (Logoff)
Подключиться (Logon)
Послать (Send)
Конструкторы:
По умолчанию
Описание:
Предназначен для доступа к почтовой системе, установленной на компьютере. Используется технология MAPI.
Доступность:
Тонкий клиент, толстый клиент.
Пример:
Почта = Новый Почта;


Как показывает практика не всегда работает.


Лучше использовать код ниже, НО естественно переделать по своим примочкам и условиям, ибо он вообще не универсальный. А вот сделать симбиоз этих 2х методов, тогда может что то и получиться хорошее.

ИмяФайла = "файл.XLS";
	
	// Попытка инициализации Outlook
	Попытка
		Outlook = Новый COMОбъект("Outlook.Application");
	Исключение
		Предупреждение("Не получилось создать объект Outlook.Application!");
		Возврат;
	КонецПопытки;
	
	// Попытка сохранения отчета
	Попытка
		ЭлементыФормы.ПолеТабДок.Записать(КаталогВременныхФайлов() + ИмяФайла, ТипФайлаТабличногоДокумента.XLS);
	Исключение
		Предупреждение("Не удалось создать файл " + ИмяФайла + "!");
		Возврат;
	КонецПопытки;
	
	// Заполнение реквизитов письма
	Письмо = Outlook.CreateItem(0);
	Письмо.Subject = "Какая то тема";                       // Тема
	Письмо.Body    = "Какойто текст"; // Текст письма
	//Письмо.to      = "";                // Адрес получателя
	Письмо.Attachments.Add(КаталогВременныхФайлов() + ИмяФайла); // Вложение
	
	// Попытка открытия подготовленного письма
	Попытка
		Письмо.Display();
	Исключение
	КонецПопытки;
Показать
Оставьте свое сообщение