Загрузка из EXCEL в 1С. MS ADODB.Connection

Публикация № 163640

Разработка - Практика программирования

1C Предприятие Импорт Загрузка Чтение Microsoft MS Excel LibreOffice OpenOffice dbf dBase xml mxl ActiveX ADO ADODB Windows

ПРАКТИЧЕСКОЕ ПОСОБИЕ РАЗРАБОТЧИКА: Метод "MS ADODB" (ADODB.Connection).
Поддерживаемые типы: *.xls,*.xlsx.

 В данной статье приведен функционал, с помощью которого в обработке
"Импорт из EXCEL и др.источников (xls,xlsx,ods,sxc,dbf,mxl,csv,sql) в 1С": //catalog.mista.ru/public/120961
производится считывание данных из файлов табличного типа *xls, *.xlsx.

Методы загрузки из внешнего источника:
- Метод "MS ADO" (Чтение файлов xls, xlsx средствами Microsoft ADO): //catalog.mista.ru/public/163640/
- Метод "MS EXCEL" (Чтение файлов xls, xlsx с картинками средствами Microsoft Office): //catalog.mista.ru/public/163641/
- Метод "LO CALC" (Чтение файлов xls, xlsx, ods, sxc с картинками средствами LibreOffice): //catalog.mista.ru/public/163642/
- Метод "NativeXLSX" (Чтение файлов xlsx с картинками средствами 1С. ПостроительDOM): //catalog.mista.ru/public/300092/
- Метод "NativeXLSX". Предыдущий вариант (Чтение файлов xlsx средствами 1С. ЧтениеXML):
//catalog.mista.ru/public/225624/
- Метод "Excel1C" (Загрузка на платформе 8.3.6 с картинками. Чтение файлов xls, xlsx, ods): //catalog.mista.ru/public/341855/
- Список листов файла: //catalog.mista.ru/public/163724/


Публикаций на тему загрузки из EXCEL - множество, но
"
— Вам билетёр нужен?
— Был нужен, да уже взяли.
— Может и я на что сгожусь?
— Может и сгодишься, если скалиться не будешь ...
"
"НЕУЛОВИМЫЕ МСТИТЕЛИ" (1966).


// Метод "Microsoft ADODB"/
//

// Параметры:
//        ФайлEXCEL - Полное имя файла (путь к файлу с именем файла и расширением).
//        ИмяЛиста - Имя выбранного листа файла EXCEL.
//        СтрокаЗаголовка (по умолчанию = 1) - Номер строки EXCEL, в которой расположены заголовки колонок.
//            Не используется, т.к. в СтрокеСоединения указано HDR=YES, а не HDR=NO.
/ /       В обработке 1-я строка анализируется для сопоставления колонок EXCEL с реквизитами 1С (справочники, докуметны, регистры).
//        НачСтрока (по-умолчанию = 0) - Номер начальной строки, начиная с которой считываются данные из EXCEL.

//        КонСтрока (по-умолчанию = 0) - Номер конечной строки, которой заканчиваются считываемые данные из EXCEL.
//            Если НачСтрока=0 и КонСтрока=0, то считывается вся таблица, находящаяся на листе EXCEL.
//        КолвоСтрокExcel - Количество строк на листе "ИмяЛиста" EXCEL. Возвращается в вызываемую процедуру.
//        ПодключениеADODB - тип драйвера ADODB для подключения к EXCEL.
//
// Возвращаемые значения:
//         ТаблицаРезультат - Результат считывания с листа "ИмяЛиста" EXCEL.
//
Функция ЗагрузитьМетодом_MSADODB(Знач ФайлEXCEL, Знач ИмяЛиста, Знач СтрокаЗаголовка = 1, НачСтрока = 0, КонСтрока = 0, КолвоСтрокExcel,
Знач
ПодключениеADODB = "MicrosoftJetOLEDB40") Экспорт
    Перем СonnectionString, ADODBConnection, ADODBRecordset, ТекстЗапроса;
    Перем КолвоКолонокExcel, Поле, Колонка, ИмяКолонки;
    Перем НоваяСтрока, НомерСтроки;
    Перем ТаблицаРезультат;
    
    // Нумерация MS ADODB начинается с 1.
    
    // Переменная "СтрокаЗаголовка", не используется, т.к. HDR=YES, а не HDR=NO.
    // HDR=YES:
    // 1. Считывание заголовков колонок с 1-ой строки.
    // 2. Считываемые данные со 2-ой и последующих строк типизированы. Для варианта HDR=NO: считываемые данные - строка.
    
    // Строка соединения - определение драйвера, который будет использован для подключения к файлу EXCEL.
    Если ПодключениеADODB = "MicrosoftACEOLEDB12" Тогда
        
        // ACE.OLEDB.12.0 - Для использования данного подключения необходимо дополнительное ПО:
        // Microsoft Access Database Engine 2010 Redistributable 32/64 bit.
        СonnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source= " + СокрЛП(ФайлEXCEL) + ";Extended Properties=""Excel 12.0;HDR=YES;IMEX=1;""";
        
        // Еще один вариант.
        //СтрокаСоединения = "Driver={Microsoft Excel Driver (*.xls, *.xlsx, *.xlsm, *.xlsb)};Dbq=" + СокрЛП(ФайлEXCEL) + ";";
        
    Иначе
        
        // Jet.OLEDB.4.0 - Стандартное подключение, как правило, не требующее установки дополнительного ПО.
        // Рекомендуется установить последний Service Pack Windows.
        СonnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source= "  + СокрЛП(ФайлEXCEL) + ";Extended Properties=""Excel 8.0;HDR=YES;IMEX=1;""";
        
        // Еще один вариант.
        //СтрокаСоединения = "Driver={Microsoft Excel Driver (*.xls)};Dbq=" + СокрЛП(ФайлEXCEL) + ";";
        
    КонецЕсли;
    
    Попытка
        // Инициализация основного объекта ADODB.Connection. Открытие соединения.
        ADODBConnection = Новый COMОбъект("ADODB.Connection");
        ADODBConnection.ConnectionString =  СonnectionString;
        ADODBConnection.Open();
        // Импирически определенный параметр для правильного определения количества строк листа.
        ADODBConnection.CursorLocation = 3;    // По-умолчанию 2.
    Исключение
        Сообщить(НСтр("ru = '"+ОписаниеОшибки()+"'"), СтатусСообщения.Внимание);
        Возврат Новый ТаблицаЗначений;    // В случае ошибки возвращаем пустую таблицу значений.
    КонецПопытки;
    
    ТекстЗапроса = "SELECT * FROM [" + ИмяЛиста + "$]";
    
    // Создание Recordset. Дочерний объект ADODBConnection. Набор записей по запросу.
    Попытка
        ADODBRecordset = Новый COMОбъект("ADODB.Recordset");
        ADODBRecordset.Open(ТекстЗапроса, ADODBConnection);
        
        // Проверка заполненности листа.
        Если (ADODBRecordset.EOF ИЛИ ADODBRecordset.BOF) Тогда
            КолвоСтрокExcel = 0;
            Сообщить(НСтр("ru = '" + ИмяЛиста + ": не содержит данных.'"), СтатусСообщения.Внимание);
            
            // Завершение работы.
            // Закрытие Объектов.
            ADODBRecordset.Close();
            ADODBConnection.Close();
            ADODBRecordset   = Неопределено;
            ADODBConnection = Неопределено;
            
            Возврат Новый ТаблицаЗначений;    // В случае ошибки возвращаем пустую таблицу значений.
        КонецЕсли;
        
        // Импирически определенные параметры для правильного определения количества строк листа.
        ADODBRecordset.AbsolutePage     = 1;
        ADODBRecordset.AbsolutePosition = 1;
    Исключение
        Сообщить(НСтр("ru = '"+ОписаниеОшибки()+"'"), СтатусСообщения.Внимание);
        Возврат Новый ТаблицаЗначений;    // В случае ошибки возвращаем пустую таблицу значений.
    КонецПопытки;
    
    // Параметр, возвращаемый в вызывающую процедуру.
    КолвоСтрокExcel = ADODBRecordset.RecordCount + 1;    // (+1) - учет Строки-Заголовока, которая "съедается".
    КолвоКолонокExcel = ADODBRecordset.Fields.Count;
    
    // Проверка заполненности листа.
     Если КолвоСтрокExcel <= 2
Тогда
        КолвоСтрокExcel = 0;
        Сообщить(НСтр("ru = '" + ИмяЛиста + ": не содержит данных.'"), СтатусСообщения.Внимание);
        
        // Завершение работы.
        // Закрытие Объектов.
        ADODBRecordset.Close();
        ADODBConnection.Close();
        ADODBRecordset   = Неопределено;
        ADODBConnection = Неопределено;
        
        Возврат Новый ТаблицаЗначений;    // В случае ошибки возвращаем пустую таблицу значений.
    КонецЕсли;
    
    // Создание результирующей таблицы, в которую будут записываться считанные из EXCEL данные.
    ТаблицаРезультат = Новый ТаблицаЗначений;
    
    // Формирование колонок результирующей таблицы.
    
    // "НомерСтроки" - для наглядности и удобства.
    // В зависимости от разрабатываемой обработки.
    // "Сопоставлено" - может быть другим.
    // Здесь же могут быть добавлены другие колонки, не формируемые из содержимого файла EXCEL.
    ТаблицаРезультат.Колонки.Добавить("НомерСтроки", Новый ОписаниеТипов("Число"), "№", 4);
    ТаблицаРезультат.Колонки.Добавить("Сопоставлено", Новый ОписаниеТипов("Булево"), "Сопоставлено", 1);
    Для ит = 1 ПО КолвоКолонокExcel Цикл
        
        Поле = ADODBRecordset.Fields.Item(ит - 1);
        ИмяКолонки = "К_" + ит;
        Колонка = ТаблицаРезультат.Колонки.Добавить(ИмяКолонки, , СокрЛП(СтрЗаменить(Поле.Name, "#", ".")));
        // Замена "#" на ".", т.к. при считывании ADODB "." в имени колонки заменяется на "#".
        
    КонецЦикла;
    
    // ТаблицаРезультат: 1-я строка - Строка-Заголовок.
    
    // Добавление этой строки обусловлено исключительно из соображений идентичности содержимого файла EXCEL и ТаблицыЗначений,
    // выводимой на форме Обработки, и дальнейшей обработки строки заголовка
    // с целью сопоставления колонок EXCEL и реквизитов 1С: для Справочников, ПВХ, Регистров, Документов.
    
    // Если в Вашей обработке в результирующей таблице в качестве 1-ой строки не нужна Строка-Заголовок, то
    // следует закомментировать следующий цикл:
    НоваяСтрока = ТаблицаРезультат.Добавить();
    НоваяСтрока.НомерСтроки = 1;
    Для ит = 1 ПО КолвоКолонокExcel Цикл
        
        ИмяКолонки = "К_" + ит;
        Колонка = ТаблицаРезультат.Колонки.Найти(ИмяКолонки);
        НоваяСтрока[ИмяКолонки] = Колонка.Заголовок;
        
    КонецЦикла;
    
    // ТаблицаРезультат: Формирование строк по указанному диапазону: НачСтрока - КонСтрока.
    
    НомерСтроки = 1;
    Пока ADODBRecordset.EOF() = 0 Цикл
        
        НомерСтроки = НомерСтроки + 1;
        
        Если НомерСтроки < НачСтрока Тогда    // Номер строки вне диапазона считываемых строк.
            ADODBRecordset.MoveNext();             // Следующая строка.
            Продолжить;
        КонецЕсли;
        
        Если КонСтрока > 0 И НомерСтроки > КонСтрока Тогда    // Номер строки вне диапазона считываемых строк.
            Прервать;
        КонецЕсли;
        
        НоваяСтрока = ТаблицаРезультат.Добавить();
        НоваяСтрока.НомерСтроки = НомерСтроки;
        
        Для ит = 1 ПО КолвоКолонокExcel Цикл
            
            Поле = ADODBRecordset.Fields.Item(ит - 1);
                
            Если Поле.ActualSize = 0 Тогда        // Пустое поле EXCEL.
                Продолжить;
            КонецЕсли;
                
            ЗначениеЯчейки = Поле.Value;        // Учитывая параметр HDR=YES в строке соединения, данные считываются в соответствии с их типом.
            
            ИмяКолонки = "К_" + ит;
            НоваяСтрока[ИмяКолонки] = ЗначениеЯчейки;
            
            // Используется при формировании таблицы на форме обработки.
            ШиринаКолонки = ТаблицаРезультат.Колонки[ИмяКолонки].Ширина;
            ДлинаСтроки      = СтрДлина(СокрЛП(ЗначениеЯчейки));
            ТаблицаРезультат.Колонки[ИмяКолонки].Ширина = ?(ШиринаКолонки < ДлинаСтроки, ДлинаСтроки, ШиринаКолонки);
                
        КонецЦикла;
        
        ADODBRecordset.MoveNext();   // Следующая строка.
        
    КонецЦикла;
    
    //УдалитьКолонкиСНулевойШириной(ТаблицаРезультат);
    
    // Завершение работы.
    // Закрытие Объектов.
    ADODBRecordset.Close();
    ADODBConnection.Close();
    ADODBRecordset   = Неопределено;
    ADODBConnection = Неопределено;
    
    Возврат ТаблицаРезультат;

    
КонецФункции

Преимущества:
1.«В общем случае» метод «Microsoft ADODB» работает и в файловом и в клиент-серверном варианте.
2. Самый быстрый из трех рассматриваемых.
Особенности и Ограничения:
1.Для функционирования метода «Microsoft ADODB» необходимо:

Драйвер подключения Provider=Microsoft.Jet.OLEDB.4.0:
- Установленный Microsoft MDAC, как правило специальная установка не требуется, достаточно последнего Service Pack-а операционной системы..
  Microsoft MDAC 2.8 SP1 10.05.2005: http://www.microsoft.com/download/en/details.aspx?displaylang=en&id=5793

Драйвер подключения Provider=Microsoft.ACE.OLEDB.12.0:
- Установленный Microsoft Access Database Engine 2010 Redistributable (16/12/2010) 32 и 64 - разрядные версии:
  Microsoft ADE 2010 16/12/2010:  http://www.microsoft.com/en-us/download/details.aspx?id=13255

2. 1-я строка файла EXCEL - строка, содержащая заголовки колонок. Можно изменить, изменив HDR=YES на HDR=NO + некоторые изменения в функции.

МА! С уважением к сообществу МА!

Специальные предложения

Комментарии
Избранное Подписка Сортировка: Древо развёрнутое
Свернуть все
1. coch 25 30.11.12 09:57 Сейчас в теме
Есть ещё нюанс. Если в первых 8-ми строках числа, 0 например, хотя дальше пойдут строки, "1,5 EUR" например, то автоопределение типа данных в ячейке возмет число для всей колонки, и все значения с типом строка будут 0, соответственно.
Параметр строки подключения MAXSCANROW лично мне никак не помог решить эту проблему. Свойства ячеек на автоопределение типа тоже не влияют.
З.Ы. Это для Microsoft.Jet.OLEDB.4.0
с Microsoft.ACE.OLEDB.12.0 не работал.
Kinestetik; ditiatko; Gremlin; StepByStep; +4 Ответить
2. StepByStep 3348 30.11.12 10:29 Сейчас в теме
(1) coch,
Спасибо. Надо будет обязательно это посмотреть.
72. ditiatko 39 02.11.16 10:23 Сейчас в теме
(1) coch, в 12.0 та же беда. если 8 пустых, то остальные не читает. Есть идеи как с этим бороться?
3. Ёпрст 1036 04.12.12 12:20 Сейчас в теме
Просто можно писать запрос не селект *, а к конкретной колонке и её уже кастовать к нужному типу данных.
JohnyDeath; +1 Ответить
5. coch 25 04.12.12 13:30 Сейчас в теме
(3) Ёпрст, естественно select не *, а конкретные поля. Чтобы использовать Cast надо через MSSQL (например) делать запрос к таблице (в 7.7 лет 5 назад так и было)
(4) djd.sf, пробовал, не взлетело. Была таблица для сверки остатков из 7.7 значение колонки с остатками выглядело как "5.000 EUR 15", если в первых 8 строках "", то значения всех строк приводились к типу число.
7. djd.sf 04.12.12 13:38 Сейчас в теме
(5) IMEX отключите и взлетит. только, что проверил.(а вообще покажите строку подключения).
8. coch 25 04.12.12 14:45 Сейчас в теме
(7) djd.sf, уже не могу показать строку подключения, т.к. эта проблема была на предыдущем месте работы.
IMEX надо бы запомнить. при оказии попробовать.
4. djd.sf 04.12.12 12:59 Сейчас в теме
типизировать можно прямо в самом запросе, только не CAST(это T-Sql), а функциями http://msdn.microsoft.com/en-us/library/s2dy91zy.aspx . Наример: SELECT CDbl(F11) FROM ['Прайс-лист$']
ded00786; StepByStep; romansun; +3 Ответить
9. romansun 191 04.12.12 16:12 Сейчас в теме
(4)
+1

вполне можно поюзать функционал вот того скуля, да

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

Единственное, так и не вычислил как в этом скуле ремарить строки - перепробовал кучи вариантов - не взлетает :). Может кто знает?
10. djd.sf 04.12.12 16:32 Сейчас в теме
(9) я себе также в консоль сделал. собственно и проверяю в ней. и временные запросы также)))
а что это такое
ремарить строки
, я не понял?
75. Alex26071991 18.10.17 07:04 Сейчас в теме
Нужна помощь.... 1с ругается на Внешнюю обработку, точнее доступ к базе...

{ВнешняяОбработка.СопоставлениеИЗагрузкаНоменклатуры.МодульОбъекта(10)}: Ошибка при вызове метода контекста (Open)
НаборДанных.Open("select * from [Test$]", Соединение);
по причине:
Произошла исключительная ситуация (Microsoft Office Access Database Engine): 'Test$' is not a valid name. Make sure that it does not include invalid characters or punctuation and that it is not too long.
{ВнешняяОбработка.СопоставлениеИЗагрузкаНоменклатуры.МодульОбъекта(10)}: Ошибка при вызове метода контекста (Open)
НаборДанных.Open("select * from [Test$]", Соединение);
по причине:
Произошла исключительная ситуация (Microsoft Office Access Database Engine): 'Test$' is not a valid name. Make sure that it does not include invalid characters or punctuation and that it is not too long.

База Скульная.
11. StepByStep 3348 05.12.12 05:18 Сейчас в теме
(4) djd.sf,
Спасибо, возьму на заметку.

Предложенное возможно, если заранее известно в какой колонке какого типа данные.
В обработке Импорт из EXCEL тремя методами это, заранее неизвестно. Именно по считыванию и определяется тип.
6. AlexO 128 04.12.12 13:36 Сейчас в теме
МА, "забыли" упомянуть самый главный плюс загрузки через ADODB - на сервере не нужна установка Excel :)
12. vamleshka 15.12.12 20:44 Сейчас в теме
Спасибо. Очень поможет, а то админ засранец не хочет покупать эксель на сервак, вот и приходилось все время мучать при загрузках экселей, т.к работал удалено на серваке.
13. GreenFox 31.01.13 01:41 Сейчас в теме
Попробовал - летает, однозначно в разы быстрее чтения через сам Ексель. Единственное но, которое мне не понравилось - надо указывать имя листа. При доступе из МС Ексель можно использовать activeworkbook и activesheet.
14. DoctorRoza 11.03.13 21:21 Сейчас в теме
Не могу понять. Есть файл екселя, настроил выгрузку в 1с, так после второго или третьего прогона выгрузки постоянно выпадает ошибка: Ошибка при вызове метода контекста (Open): Произошла исключительная ситуация (Microsoft JET Database Engine): Внешняя таблица не имеет предполагаемый формат.
У меня стоит офис 2010, крякнутый. Файл с расширением *.xlsx. Что я делаю не так?
17. StepByStep 3348 14.04.13 01:08 Сейчас в теме
(14) DoctorRoza,

Попробуйте установить Microsoft Access Database Engine 2010 Redistributable
Ссылка 32х и 64х: http://www.microsoft.com/en-us/download/details.aspx?id=13255

В настройке обработки выберите "Тип подключения ADODB" = "Excel 12.0".
И с такой настройкой осуществляйте загрузку.

Если нетрудно, отпишите, пожалуйста, о результатах.

Удачи.
76. AlexandraSerg 22 21.01.18 20:48 Сейчас в теме
(17) Здравствуйте!
у меня та же проблема.
скачала, установила Microsoft Access Database Engine 2010 Redistributable
по ссылке: http://www.microsoft.com/en-us/download/details.aspx?id=13255

установила "Тип подключения ADODB" = "Excel 12.0".
Ошибка все равно выходит: Ошибка при вызове метода контекста (Open): Произошла исключительная ситуация (Microsoft JET Database Engine): Внешняя таблица не имеет предполагаемый формат.
15. vers139 51 09.04.13 16:08 Сейчас в теме
У меня такая проблема: у поставщиков есть товар с кодом 0001. При сохранении в Excel в ячейку пишется значение 1, формат 0000. Пользователю показывается правильно: 0001. Однако при считывании данных из Excel получаю значение 1, а надо именно 0001. Можно ли это как-то "активизировать" каким-нибудь параметром?
18. StepByStep 3348 14.04.13 01:35 Сейчас в теме
(15) vers139,
Самое простое - считывать ячейку как строку.
НоваяСтрока[ИмяКолонки] = Строка(ЗначениеЯчейки);
19. vers139 51 16.04.13 16:35 Сейчас в теме
ЗначениеЯчейки

это ЛистЭксель.Cells(СтрокаЭксель, НомерКолонкиКод).Value?
20. StepByStep 3348 17.04.13 21:27 Сейчас в теме
21. Pawlick 17.05.13 09:51 Сейчас в теме
Братцы, а мне нужно в цикле перебирать строки и получить доступ к свойствам строки.
Никак не воткнусь как это сделать?

т.е в случае подключения через
Excel = Новый COMОбъект("Excel.Application");
Excel.WorkBooks.Open(ИмяФайла);
ExcelЛист = Excel.Sheets(НомерЛистаExcel);

есть возможность сдалать так:
ExcelЛист.Rows(НомерСТроки).___

А вашем случае взлетит?
22. unoDosTres 28.05.13 10:25 Сейчас в теме
вообще какойто весьма неудобный способ считывания (воспользовался только изза отсутствия экселя на машине)... много лишнего кода писать приходится, да и методы и функции длл не везде найдешь, писал обработку ЗТЧ на этой приблуде, видимо изза недостатка знаний пришлось такой кривокод нагородить что ппц, мало того что из цикла хрен пойми когда выходит, после считывания файла Экселя, уже по всем строкам пробежал а EOF никак достичь не могу, пришлось писать принудительный выход, да и потом наперед ведь не знаешь длину файла, а метода этой длл для его определения я и не знаю.. короче разочаровался..
23. echo77 1148 01.10.13 14:10 Сейчас в теме
зашифрованные листы не читает
24. StepByStep 3348 03.10.13 21:46 Сейчас в теме
(23) echo77,
Если Вы имеете в виду запароленную книгу - то да - не читает, как впрочем и другие.
28. Shade 2 13.03.14 01:28 Сейчас в теме
(24) уважаемый МА :) скажите пожалуйста, можно ли переделать имеющийся код загрузки Эксель методом на ADODB? Вот сам код:
Процедура ЗагрузитьФайл(Объект,ИмяТабличнойЧасти)
Екс = Новый COMОбъект("Excel.Application");

Попытка
ВыбрФайл = Екс.WorkBooks.Open(ПолноеИмяФайла); //Открываем файл
ОК = Истина;
Исключение
Предупреждение("Неудалось открыть файл");
КонецПопытки;

Если ОК = Истина Тогда
Sheet = Екс.Sheets(1); //Номер листа

Если Объект[ИмяТабличнойЧасти].Количество() > 0 Тогда

ТекстВопроса = "Перед заполнением табличная часть будет очищена. Заполнить?";
Ответ = Вопрос(ТекстВопроса, РежимДиалогаВопрос.ДаНет, , КодВозвратаДиалога.Да, Объект.Метаданные().Имя);
Если Ответ <> КодВозвратаДиалога.Да Тогда
Возврат;
КонецЕсли;

Объект[ИмяТабличнойЧасти].Очистить();
КонецЕсли;

// обработка файла
Стр = НомПервойСтроки;
Пока Стр <= НомПоследнейСтроки Цикл
Строка = Объект[ИмяТабличнойЧасти].Добавить();

Строка.Представление = СокрЛП(Sheet.Cells(Стр, ПредставлениеДок).Value);

Попытка
Строка.Дебет = Число(Sheet.Cells(Стр, КолДеб).Value);
Исключение
Строка.Дебет = 0;
КонецПопытки;

Попытка
Строка.Кредит = Число(Sheet.Cells(Стр, КолКред).Value);
Исключение
Строка.Кредит = 0;
КонецПопытки;

Попытка
Строка.Дата = Дата(Sheet.Cells(Стр, КолДата).Value);
Исключение
Строка.Дата = "";
КонецПопытки;

Стр = Стр + 1;
КонецЦикла;
КонецЕсли;

Екс.WorkBooks.Close();
КонецПроцедуры

Заранее спасибо за ответ
32. StepByStep 3348 13.03.14 10:12 Сейчас в теме
(28) Shade,
Предложенная Вами загрузка относится к другому методу, описанному мною в статье:
Загрузка из EXCEL в 1С /3+1 метод/. MS EXCEL.Application: http://infostart.ru/public/163641/
+ Дебет/Кредит и др. - это уже по необходимости.
25. spaminfostart 15 05.03.14 14:44 Сейчас в теме
Не подходит для файла с числом столбцов более 255.
1Cnick.sk; +1 Ответить
29. StepByStep 3348 13.03.14 09:12 Сейчас в теме
(25) spaminfostart,
СПАСИБО.
"Не подходит для файла с числом столбцов более 255."
Откровенно говоря, на таком большом количестве колонок не тестировал.
Надо посмотреть.
55. AlexO 128 26.04.15 21:31 Сейчас в теме
(29)
Откровенно говоря, на таком большом количестве колонок не тестировал.
Это при подключении ADODB и старом Excel. В новом Эксель ограничение убрали...
80. 1Cnick.sk 22.01.19 10:21 Сейчас в теме
(29)
(55) Что значит в старом или новом? У меня 2010 - ограничение есть.
81. GreenDragon 22.01.19 15:49 Сейчас в теме
(80) 2010 - это не актуальная версия. Это 8 с лишним лет назад
26. Shade 2 11.03.14 18:55 Сейчас в теме
Огромное спасибо!!! Со старой версией майкрософтовского движка и правда иногда возникала проблема тип Число у колонки, от чего не типовые значения слетали, с новым все тип топ, только пришлось установить обе компоненты http://www.microsoft.com/download/en/details.aspx?id=23734 и http://www.microsoft.com/en-us/download/details.aspx?id=13255 с одной той что в шапке не взлетело.
Спасибо!
30. StepByStep 3348 13.03.14 10:04 Сейчас в теме
(26), (27) Shade,
Мне на Win7/8 x64 достаточно было http://www.microsoft.com/en-us/download/details.aspx?id=13255

http://www.microsoft.com/en-us/download/details.aspx?id=23734:
Version: Date Published:
2 10/3/2008
File name: File size:
AccessDatabaseEngine.exe 25.3 MB

http://www.microsoft.com/en-us/download/details.aspx?id=13255:
Version: Date Published:
SP2 7/22/2013
File name: File size:
AccessDatabaseEngine.exe 25.3 MB
AccessDatabaseEngine_x64.exe 27.3 MB
31. Shade 2 13.03.14 10:11 Сейчас в теме
(30) я написал, вдруг у кого не запустится, как у меня, решение нашел на мисте, у человека тоже не заработало, он установил второй пакет все завелось, мне тоже помогло :) он говорил про 7. у меня не завелось на foundation 2012 server :)
33. StepByStep 3348 13.03.14 10:14 Сейчас в теме
(31) Shade,
ХОРОШО. Кому-то может пригодиться.
34. Karlitos 17.04.14 15:47 Сейчас в теме
(33) огромное спасибо! Статья очень помогла реализовать загрузку цен из прайс-листов в формате .XLS. Раньше все было завязано на Excel, теперь всем OpenOffice накатили)
57. Flares 21.12.15 18:01 Сейчас в теме
(30) подскажите с чем может быть связана такая проблема, ADODBRecordset.Fields.Count работает максимум до 52 колонки, как только этот лимит превышается (53 колонки в файле) все равно выдает 52 и попытка прочитать содержимое в 53 колонке выдает ошибку. Кто-то писал про предел в 255 - но тут и близко нет!!! У меня стоит Microsoft Access Database Engine 2010 32x тип подключения соотв "Excel 12.0" На другом сервере грузится, НО на нем никогда не устанавливался Офис. похоже дело в офисе или его кривой версии.
59. StepByStep 3348 24.12.15 17:24 Сейчас в теме
(57) Flares,
Нет ли в файле множества скрытых колонок, или объединенных ячеек, состоящих из множества ячеек. Такое бывает.
Можно попытаться пересохранить файл в MS Office.
60. Flares 01.02.16 15:46 Сейчас в теме
(59) Нет ни скрытых ни объединенных. Ни Пересохранение файла, ни переустановка Microsoft Access Database Engine 2010 не помогает :( Оч. странно.
64. StepByStep 3348 20.07.16 13:01 Сейчас в теме
(60) Flares,
Попробуйте "поиграть" с разными строками соединения:

// Основные.
1. ("Jet_OLEDB_4_0_EXCEL_8_0" , "Provider=Microsoft.Jet.OLEDB.4.0;Data Source= " + СокрЛП(ФайлEXCEL) + ";Extended Properties=""EXCEL 8.0;HDR=YES;IMEX=1;""")
2. ("EXCEL_Driver_XLS", "Driver={Microsoft EXCEL Driver (*.xls)};Dbq= " + СокрЛП(ФайлEXCEL) + ";ReadOnly=1;")
3. ("ACE_OLEDB_12_0_EXCEL_12_0_XML", "Provider=Microsoft.ACE.OLEDB.12.0;Data Source= " + СокрЛП(ФайлEXCEL) + ";Extended Properties=""EXCEL 12.0 XML;HDR=YES;IMEX=1;""")
4. ("EXCEL_Driver_XLSX", "Driver={Microsoft EXCEL Driver (*.xls, *.xlsx, *.xlsm, *.xlsb)};Dbq=" + СокрЛП(ФайлEXCEL) + ";ReadOnly=1;")
// Дополнительные.
5. ("Jet_OLEDB_4_0_EXCEL_9_0" , "Provider=Microsoft.Jet.OLEDB.4.0;Data Source= " + СокрЛП(ФайлEXCEL) + ";Extended Properties=""EXCEL 9.0;HDR=YES;IMEX=1;""")
6. ("ACE_OLEDB_12_0_EXCEL_8_0", "Provider=Microsoft.ACE.OLEDB.12.0;Data Source= " + СокрЛП(ФайлEXCEL) + ";Extended Properties=""EXCEL 8.0;HDR=YES;IMEX=1;""")
7. ("ACE_OLEDB_12_0_EXCEL_12_0", "Provider=Microsoft.ACE.OLEDB.12.0;Data Source= " + СокрЛП(ФайлEXCEL) + ";Extended Properties=""EXCEL 12.0;HDR=YES;IMEX=1;""")
87. chemezov 30 13.09.19 03:35 Сейчас в теме
27. Shade 2 11.03.14 18:56 Сейчас в теме
от операционки зависит если вин 7 или сервер фаундейшн 2012 64 бит то нужно обе
35. Mraque 16.10.14 16:54 Сейчас в теме
StepByStep, спасибо большое за развернутую статью.
36. mihast 66 21.10.14 08:21 Сейчас в теме
Жаль, что картинки так не загрузить...
Или просто ЗДЕСЬ не описано ?
37. Bukaska 133 21.10.14 16:22 Сейчас в теме
(36) mihast, Почему не загрузить?
Обратите внимание на мигающую голубую ссылку внизу сообщения: Прикрепить файл
Ниже неё есть только галка: Подписаться на ответы этой темы.
далее внизу уже только кнопки: Ответить и Просмотр
Не можем искать сверху вниз, ищите согласно моего комментария снизу вверх)
38. Mraque 21.10.14 16:46 Сейчас в теме
Подскажите пожалуйста
:
На клиенте все работает замечательно.
Перенес код в фоновое задание, выполняющееся на сервере.
Появилась ошибка:

Ошибка при установке значения атрибута контекста (ActiveConnection)
Catalog.ActiveConnection = СтрокаПодключения;
по причине:
Произошла исключительная ситуация (ADOX.Catalog): Provider cannot be found. It may not be properly installed.


СтрокаПодключения = "
|Provider=Microsoft.Jet.OLEDB.4.0;
|Data Source="+ИмяФайла1+";
|Extended Properties=""Excel 8.0;HDR=Yes;"";";

Сервер 1С Предприятия это отдельный сервер. Везде 64-битная операционная система.
На клиенте и на нем была установлена http://www.microsoft.com/en-us/download/details.aspx?id=23734. Но не помогло.

В чем может быть проблема ?
39. StepByStep 3348 25.11.14 23:43 Сейчас в теме
(38) Mraque,
Возможно у пользователя, от имени которого выполняется задание, не хватает прав.
40. ssa 26.11.14 18:29 Сейчас в теме
Загружаю указанным методом файл. Значения, находящиеся в одной колонке файла переносятся в результирующую таблицу как-то странно:
ЗначенияВФайле |  ЗначенияВТаблице
14,24          | 14,24
49,30          | 49,3
98,60          | 98,59999999999999
147,89         | 147,89
71,18          | 71,18000000000001

Т.е. непонятно, почему так с разрядностью некоторых чисел происходит.
В файле для всей колонки установлен числовой тип с точностью 2.
Почему так может быть?
41. StepByStep 3348 27.11.14 13:41 Сейчас в теме
(40) ssa,
Такое наблюдал. Это некритично, т.к. в дальнейшем приводя к значению определенного реквизита 1С произойдет правильное округление.
В реальности в файле может находиться значение 98,59999999999999 (внутреннее содержание ячейки), которое средствами форматирования excel-ячейки приводится к виду 98,60.
42. ssa 27.11.14 14:49 Сейчас в теме
(41)
В том то и дело, что в файле значение 98,6 - сам вбивал )
43. StepByStep 3348 27.11.14 21:09 Сейчас в теме
(42) ssa,
Что ж, оставим это на совести мелкософта.
44. ssa 28.11.14 01:00 Сейчас в теме
(43) StepByStep
Да, придется принять как данное. Буду работать со строковыми значениями.
83. forsagforsag 71 10.04.19 23:40 Сейчас в теме
Windows Server 2012R2 (так же на Win7 Pro) выдает одинааковую ошибку:

ВнешняяОбработка.ВнешняяОбработка1.Форма.Форма.Форма(40)}: Ошибка при вызове метода контекста (Open)
ADODBRecordset.Open(ТекстЗапроса, ADODBConnection);
по причине:
Произошла исключительная ситуация (ADODB.Recordset): Невозможно использование подключения для выполнения операции. Оно закрыто или не допускается в данном контексте.
45. mvgfirst 4 07.01.15 18:05 Сейчас в теме
Вопрос знатокам:
Как с помощью ADO получить информацию о сгруппированных строках на листе Excel?

Некоторые из поставщиков не дублируют группирующее поле в колонке листа.
(особенно те которые формируют прайс-листы из 1С)... и если группировка одноуровневая то это еще по божески. Можно как-то при загрузке отличить группу от товара.

А как быть когда групп много и они вложены друг в друга?
46. kuza_87 26 06.02.15 09:07 Сейчас в теме
На получается считать данные. Пробую "MicrosoftJetOLEDB40" - внешняя таблица не имеет предполагаемый формат
"MicrosoftACEOLEDB12" - Не удается найти указанный поставщик. возможно, он установлен неправильно.

То что вы писали установить - я установил

Опериционка - Server 2008 R2
47. kuza_87 26 06.02.15 09:11 Сейчас в теме
48. kuza_87 26 06.02.15 09:24 Сейчас в теме
Проблема решилась после перезагрузки сервера. Извините за беспокойство, и спасибо за программу
49. cmd_vasec 34 25.03.15 11:59 Сейчас в теме
У меня в файловом варианте все работает, а в клиент-серверном выдает ошибку: {Форма.Форма.Форма(266)}: Ошибка при вызове метода контекста (Open): Произошла исключительная ситуация (ADODB.Connection): Не удается найти указанный поставщик. Вероятно, он установлен неправильно.

все делал на сервере, права админа.
68. Shurik1C 01.08.16 11:37 Сейчас в теме
(49) cmd_vasec,

тоже такая хрень была
ничего из выше описанного не помогло

в итоге вылечил вот этим

https://www.microsoft.com/en-us/download/details.aspx?id=23734
69. GreenDragon 02.09.16 02:11 Сейчас в теме
(68) Shurik1C, не забываем, что клиент 1С - 32-х битный. Могу предположить, что Сервер 1С в вашей ситуации был 64-битный. Соответственно, если компонента стоит 32-битная, то сервер не сможет с ней работать, тогда как клиент - легко. Ну, и обратная ситуация. Решил аналогичную проблему (у меня Сервер читал, а Клиент - нет) просто передачей файла на сервер через ВременноеХранилище. Кстати, нюанс битности в контексте 1С при работе с ADO, мало кто затрагивает.
50. cmd_vasec 34 25.03.15 12:22 Сейчас в теме
51. fzt 25.03.15 12:28 Сейчас в теме
(50) cmd_vasec, сделай обертку СОМ объекта как тут
http://infostart.ru/public/197627/
53. bacila 03.04.15 19:49 Сейчас в теме
(50) cmd_vasec, надо добавить такие ключи, и прописать в них значения и Microsoft Access Database Engine 2010 надо 64 битный

ОС: 64bit офис: 64bit) или (ОС: 32bit офис: 32bit)

Ключ: HKCR \ CLSID \ {3BE786A0-0366-9434-4F5C-25CF162E475E} \ InprocServer32 \

Параметр: (По умолчанию)

Данные значения: C: \ Program Files \ Common Files \ Microsoft Shared \ Office14 \ ACEOLEDB.DLL


(ОС: 64bit офис: 32bit)

Ключ: HKCR \ Wow6432Node \ CLSID \ {3BE786A0-0366-9434-4F5C-25CF162E475E} \ InprocServer32 \

Параметр: (По умолчанию)

Данные значения: C: \ Program Files (x86) \ Common Files \ Microsoft Shared \ Office14 \ ACEOLEDB.DLL
52. cmd_vasec 34 25.03.15 12:36 Сейчас в теме
проблему решил установкой Microsoft Access Database Engine 2010 Redistributable (16/12/2010) 64 - разрядной версии.
54. StepByStep 3348 04.04.15 17:06 Сейчас в теме
(52) cmd_vasec,
Хорошо. Это описано здесь http://infostart.ru/public/120961/
Надо было конечно это и здесь описать.
56. XelOla 17 18.10.15 08:44 Сейчас в теме
(54)
Здравствуйте! Попыталась воспользоваться вашей обработкой.
Вызов - ЗагрузитьМетодом_MSADODB(Файл, "Работники",,,,1);
Ваша функция Функция ЗагрузитьМетодом_MSADODB(Знач ФайлEXCEL, Знач ИмяЛиста, Знач СтрокаЗаголовка = 1, НачСтрока = 0, КонСтрока = 0, КолвоСтрокExcel,
Знач ПодключениеADODB = "MicrosoftJetOLEDB40") Экспорт - полная копия.
Файл - строк штук 15, столбцов 8. Некое подобие табеля.
При определении падает в
Сon nectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source= " + СокрЛП(ФайлEXCEL) + ";Extended Properties=""Excel 8.0;HDR=YES;IMEX=1;""";
Потом ошибка
{Форма.Форма.Форма(87)}: Ошибка при вызове метода контекста (Open): Произошла исключительная ситуация (Microsoft JET Database Engine): Определено слишком много полей.
Хм... а другой файл прочел. Я пока не нашла в чем причина...
58. StepByStep 3348 24.12.15 17:21 Сейчас в теме
(56) XelOla,
Существует ограничение на 255 колонок для файла типа xlsx.
1Cnick.sk; +1 Ответить
61. lev6975 15.04.16 18:56 Сейчас в теме
У меня с датами траблы - в экселе стоит тип ячейки"дата". В 1С летит номер дня с 01.01.1900 года... селектил с типом CDate,некоторые берет, но, тогда, не все даты берет, почему - то. А, некоторые, попросту не считывает и возвращает пустое поле... В режиме CSTR грузит числами дня с 1900 года...Например, дата 16.04.2016 это 42476
день с 01.01.1900...Хорошо бы, просто, строкой дату показывал...В 1С ее можно самому привести
62. fzt 20.04.16 12:19 Сейчас в теме
(61) lev6975, в соседней ветке отписался. Не помогло?
65. StepByStep 3348 20.07.16 13:04 Сейчас в теме
(61) lev6975,
Попробуйте вместо HDR=YES использовать HDR=NO.
63. prelest' 18.07.16 12:45 Сейчас в теме
Есть проблема с чтением некоторых ячеек, возвращает пустое поле. В таблице в ячейке стоит текст, а в 1С NULL. Скажите в чем может быть косяк?
66. StepByStep 3348 20.07.16 13:06 Сейчас в теме
67. prelest' 26.07.16 13:00 Сейчас в теме
(66)
Спасибо.

На одном из форумов нашла:
"Смешанные данные в колонках (подводный камень способный попортить не мало крови) Из-за настроек по умолчанию Excel ваша программа нормально считывающая данные из полностью заполненных таблиц, может сбиться на тех таблицах, в первых N (>8) записях которых пустые значения.
В результате, когда доходит до записей с не пустыми полям их значения возвращаются как NULL независимо от реального содержимого в XLS.
Для предотвращения подобной ситуации следует использовать аттрибут IMEX=1 в Extended Properties. "
70. mikeA 1 19.10.16 10:27 Сейчас в теме
// Нумерация MS ADODB начинается с 1
Нумерация с нуля вроде.
71. mikeA 1 19.10.16 11:35 Сейчас в теме
(70) mikeA,
Хотя нет, это нумерация колонок в экселе с 0
73. ditiatko 39 02.11.16 10:26 Сейчас в теме
Extended Properties = Excel 12.0;HDR=NO;IMEX=1 - при первых восьми пустых строках не читает, удаляю строки - читает
74. Bozau 03.05.17 09:52 Сейчас в теме
из неприятностей, с которыми приходилось сталкиваться с загрузкой через ADODB (и которые не получилось тогда решить) было неправильное определение типа колонки (вместо строки - число) и приведение длинных цепочек цифр к экспоненциальной форме записи. Очень неприятно получать в качестве штрихкода товара запись типа "4,67Е13", или вместо ИНН что-нибудь типа "6,67Е11"
77. pyrkin_vanya 369 05.11.18 20:25 Сейчас в теме
Добрый день. Подскажите пожалуйста, каким образом производить загрузку из файла в клиент-серверном варианте?
78. GreenDragon 05.11.18 22:16 Сейчас в теме
(77) Я реализовал через временное хранилище. На стороне клиента при отправке пакую файл и отправляю в процедуру на сервере АдресВременногоХранилища. На стороне сервера делаю примерно это:

	Если АдресВременногоХранилища <> Неопределено Тогда
		ДвоичныеДанные = ПолучитьИзВременногоХранилища(АдресВременногоХранилища);
		ИмяВременногоФайла = ПолучитьИмяВременногоФайла(Расширение);
		ДвоичныеДанные.Записать(ИмяВременногоФайла);
		ФайлEXCEL = ИмяВременногоФайла;
	КонецЕсли;
pyrkin_vanya; +1 Ответить
79. pyrkin_vanya 369 12.11.18 12:45 Сейчас в теме
(78)Строка соединения не проходит.

 СonnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source= "  + СокрЛП(ФайлEXCEL) + ";Extended Properties=""Excel 8.0;HDR=YES;IMEX=1;""";


Проходит это

СтрокаСоединения = "Driver={Microsoft Excel Driver (*.xls)};Dbq=" + СокрЛП(ФайлEXCEL) + ";";


Но, не читает некоторые значения в ячейках. Просто типа их нет.

Может кто сталкивался?
82. superlexa2008 25.02.19 16:07 Сейчас в теме
я так читаю


ТабДок = Новый ТабличныйДокумент;
ТабДок.Прочитать(ПутьКфайлу);

ТЗ = ОбщегоНазначения.ТабличныйДокументВТаблицуЗначений(ТабДок);



Функция ТабличныйДокументВТаблицуЗначений(ТабДок) Экспорт

ПЗ = Новый ПостроительЗапроса;
ПЗ.ИсточникДанных = Новый ОписаниеИсточникаДанных(ТабДок.Область());//передаем ТЗ
ПЗ.ДобавлениеПредставлений = ТипДобавленияПредставлений.НеДобавлять;
ПЗ.ЗаполнитьНастройки();
ПЗ.Выполнить();
ТЗ = ПЗ.Результат.Выгрузить();

Возврат ТЗ;

КонецФункции
Antoska; olezhe; +2 Ответить
85. olezhe 20 26.04.19 18:24 Сейчас в теме
(82) Хахахахаха! Гениально. Интересно сравнить производительность. Но таблицу в 4500 строк этот метод втягивает мгновенно.
86. GreenDragon 26.04.19 19:22 Сейчас в теме
Попробуйте скормить своему методу таблицу, в которой присутствуют объединённые ячейки.
84. olezhe 20 26.04.19 18:10 Сейчас в теме
У многих в Windows 10 возникает проблема с Microsoft.jet.oledb.4.0

Microsoft.jet.oledb.4.0 не будет работать в 64bit операционной системе (он для 32bit), вместо него следует использовать Microsoft.ACE.OLEDB.12.0
88. loki03 07.11.19 06:43 Сейчас в теме
Ошибка при установке значения атрибута контекста (AbsolutePage): Произошла исключительная ситуация (ADODB.Recordset): Текущий объект Recordset не поддерживает закладки. Это связано с ограничением поставщика или с выбранным типом курсора.

ADODBRecordset = Новый COMОбъект("ADODB.Recordset");
ADODBRecordset.Open(ТекстЗапроса, ADODBConnection);

нужно добавить

ADODBRecordset = Новый COMОбъект("ADODB.Recordset");
ADODBRecordset.CursorType=1:
ADODBRecordset.Open(ТекстЗапроса, ADODBConnection);
89. loki03 07.11.19 12:44 Сейчас в теме
И еще такая проблема. Теряется первая строка.
В файле 17222 строки, смотрю в отладчике 17221.
в чем может быть проблема, подскажите.
90. user742690 29.12.19 23:31 Сейчас в теме
Если листов в книге нет как это указать при чтении?
НаборДанных.Open("activeworkbook",Соединение);
Как правильно прописать?Подскажите,пожалуйста.
Оставьте свое сообщение

См. также

3 онлайн-курса по 1С-программированию: обмен данными, расчетные задачи и бухгалтерские задачи с 12 мая по 8 июля 2020 г. Промо

Практика программирования v8 Бесплатно (free)

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

22.04.2020    3237    23    infostart    2    

Программная работа с настройками СКД

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Нюансы программной работы с настройками системы компоновки данных в отчетах и динамических списках. Обзор всех видов настроек компоновки. Что в каких случаях правильно применять. В качестве примера рассмотрена работа с отборами и группировками.

27.01.2020    15186    0    ids79    26    

Универсальные инструменты 1С

Универсальные обработки Прочие инструменты разработчика v8 1cv8.cf Бесплатно (free)

Свободно распространяемый набор универсальных обработок и отчетов в виде расширения для разработки и поддержки, которое работает во ВСЕХ видах клиентских приложений и во всех операционных системах, которые поддерживает платформа 1С:Предприятие, кроме мобильных. Консоль запросов - консоль отчетов - консоль кода - редактор объектов базы данных - удаление помеченных объектов - поиск и удаление дублей - редактор констант - консоль заданий - групповая обработка справочников и документов - динамический список - поиск ссылок на объект - регистрация изменений для обмена данными - структура хранения базы - консоль HTTP запросов-консоль вебсервисов- консоль сравнения данных- информация о лицензиях- загрузка из табличного документа-файловый менеджер-все функции- навигатор по конфигурации-конструктор регулярных выражений-Выгрузка загрузка XML с фильтрами

21.01.2020    18496    295    cprit    84    

[СКД] Программное создание схемы компоновки данных

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Сделаем отчет на СКД полностью программно, без использования макета "схема компоновки данных".

15.01.2020    15741    0    John_d    22    

Копирование числовых ячеек из 1С в Excel Промо

Загрузка и выгрузка в Excel Администрирование данных 1С v8 1cv8.cf Бесплатно (free)

Решение проблемы, когда значения скопированных ячеек из табличных документов 1С в Excel воспринимаются последним как текст, т.е. без дополнительного форматирования значений невозможно применить арифметические операции. Поводом для публикации послужило понимание того, что целое предприятие с более сотней активных пользователей уже на протяжении года мучилось с такой, казалось бы на первый взгляд, тривиальной проблемой. Варианты решения, предложенные специалистами helpdesk, обслуживающими данное предприятие, а так же многочисленные обсуждения на форумах, только подтвердили убеждение в необходимости описания способа, который позволил мне качественно и быстро справиться с ситуацией.

15.01.2019    20224    0    itriot11    22    

Последовательности событий. Шпаргалка

Практика программирования v8 Россия Бесплатно (free)

Собрал информацию о событиях/подписках/расширениях в одном месте.

30.12.2019    10871    0    kuzyara    33    

Таблица значений. Нюансы

Практика программирования v8 Бесплатно (free)

Обзор некоторых аспектов использования общеизвестного инструмента 1С.

01.10.2019    25495    0    Yashazz    45    

[Шпаргалка] Программное создание элементов формы

Практика программирования Работа с интерфейсом v8 1cv8.cf Бесплатно (free)

Программное создание практически всех популярных элементов формы.

06.09.2019    34942    0    rpgshnik    59    

Использование программных перечислений, ч.1: строковые константы Промо

Практика программирования v8 1cv8.cf Бесплатно (free)

Часто ли у вас возникает необходимость в коде выполнять сравнение на строку?

10.12.2016    34215    0    unichkin    45    

Агрегатные функции СКД, о которых мало кто знает

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Пользуетесь ли Вы всеми возможными агрегатными функциями, которые предоставляет система компоновки данных? Если Вы используете только: СУММА, КОЛИЧЕСТВО, МИНИМУМ, МАКСИМУМ, СРЕДНЕЕ, то эта статья для Вас.

05.09.2019    37115    0    ids79    52    

Регистры бухгалтерии. Общая информация

Практика программирования Математика и алгоритмы v8 v8::БУ БУ Бесплатно (free)

Общая информация о внутреннем устройстве регистров бухгалтерии.

05.09.2019    21745    0    YPermitin    24    

Три костыля. Сказ про фокусы в коде

Практика программирования v8 Бесплатно (free)

Три интересных (или странных) костыля в коде, которые могут помочь в повседневных и не очень задачах.

03.09.2019    21871    0    YPermitin    80    

Вспомогательные инструкции в коде 1С Промо

Практика программирования v8 1cv8.cf Бесплатно (free)

Помогаем редактору кода 1С помогать нам писать и анализировать код.

15.10.2018    26222    0    tormozit    100    

Отслеживание выполнения фонового задания

Практика программирования Универсальные функции Разработка v8 1cv8.cf Бесплатно (free)

Запуск фонового задания из модуля внешней обработки. Отслеживание выполнения задания в виде прогресса, расположенного на форме.

17.08.2019    25794    0    ids79    16    

Функции СКД: ВычислитьВыражение, ВычислитьВыражениеСГруппировкойМассив

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

Подробное описание и использование внутренних функций системы компоновки данных: Вычислить, ВычислитьВыражение, ВычислитьВыражениеСГруппировкойМассив, ВычислитьВыражениеСГруппировкойТаблицаЗначений.

08.08.2019    56356    0    ids79    37    

Новости для пользователей

Универсальные обработки v8 1cv8.cf Бесплатно (free)

Для уведомления пользователей программных продуктов 1С о разных событиях, в них включена подсистема «Новостной центр». Это довольно удобная штука, т.к. новостные ленты сообщают о выходе обновлений, о новостях и событиях в сфере учёта. Но можно увеличить пользу от новостной подсистемы используя её локально в рамках 1С базы. Например, внутренняя служба техподдержки или внедряющая компания может через новостную ленту оповещать пользователей информационной базы об изменениях в программе, совещаниях, проведении тестирований, заполнения нужных документов или сдача отчетов к определенной дате и т.п.

05.08.2019    11382    20    sapervodichka    17    

Оформление и рефакторинг сложных логических выражений Промо

Практика программирования v8 Россия Бесплатно (free)

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

20.09.2012    73734    0    tormozit    129    

Фоновое выполнение кода в 1С - это просто

Практика программирования v8 1cv8.cf Бесплатно (free)

Как легко запускать выполнение в фоне, не прибегая к долгому описанию фоновых процедур.

02.08.2019    26500    0    avalakh    21    

СКД - наборы данных и связи между ними, создание собственной иерархии, вложенные отчеты

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

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

26.07.2019    42755    0    ids79    11    

СКД - использование расширений языка запросов, секция ХАРАКТЕРИСТИКИ

Инструментарий разработчика Практика программирования v8 v8::СКД Бесплатно (free)

Автоматическое и не автоматическое заполнение полей компоновки данных. Использование расширений языка запросов для СКД «{…}», секция ВЫБРАТЬ, секция ГДЕ, параметры виртуальных таблиц. Автоматизированное использование дополнительных данных в запросе: секция ХАРАКТЕРИСТИКИ.

17.07.2019    28643    0    ids79    27    

Запись значения в поле ввода/формы со срабатыванием события ПриИзменении Промо

Практика программирования v8 1cv8.cf Россия Бесплатно (free)

Иногда возникает необходимость после записи значения в какое либо поле ввода/формы вызвать для него обработчик события ПриИзменении, а о вызове самого события приходится только мечтать. В этой статье приводится программный способ вызова этого события.

11.07.2007    44794    0    tormozit    38    

Регистры сведений. За кулисами

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Небольшие заметки по внутреннему устройству регистров сведений.

09.07.2019    21541    0    YPermitin    13    

"Меньше копипаста!", или как Вася универсальную процедуру писал

Практика программирования Разработка v8 v8::СКД 1cv8.cf Бесплатно (free)

Программист Вася разбирает подход создания универсальных методов на примере программного вывода СКД.

04.07.2019    16491    0    SeiOkami    50    

Создание отчетов с помощью СКД - основные понятия и элементы

Практика программирования Математика и алгоритмы v8 v8::СКД Бесплатно (free)

Основные принципы работы СКД. Понятия схемы компоновки и макета компоновки. Описание основных элементов схемы компоновки: наборы данных, поля, вычисляемые поля, ресурсы, параметры.

25.06.2019    42412    0    ids79    20    

Как сделать из &НаКлиентеНаСервереБезКонтекста почти &НаКлиентеНаСервере Промо

Практика программирования v8 1cv8.cf Россия Бесплатно (free)

Как сделать метод формы, доступный на клиенте и на сервере одновременно, и сохранить при этом удобство разработки

10.09.2017    40586    0    tormozit    72    

Многопоточное ускорение однопользовательских нагрузок в 1С + Microsoft SQL Server 2017

Практика программирования Производительность и оптимизация (HighLoad) v8 v8::Запросы Бесплатно (free)

Взаимодействие с Microsoft SQL Server нередко вызывает трудности у 1С-ников, а потому интересны любые моменты, связанные с его использованием. О своем опыте работы с новым SQL Server 2017 участникам конференции Infostart-2018 рассказал директор ООО «Аналитика софт» Дмитрий Дудин.

11.06.2019    21459    0    dmurk    144    

Регистры накопления. Структура хранения в базе данных

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

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

16.05.2019    35466    0    YPermitin    30    

Выполнение внешней обработки в фоновом задании

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Подробное описание подхода к созданию длительной операции на основе внешней обработки. Реализация протестирована на 1С 8.3.12.1714 (x64).

11.05.2019    24303    0    Eret1k    23    

Выгрузка документа по условию Промо

Практика программирования Разработка v8 Бесплатно (free)

Что делать, если документы нужно выгружать не все подряд, а по какому-то фильтру: статусу, дате, набору условий... А что если он соответствовал этим условиям, а потом перестал? А если потом опять начал? Такие ситуации заставили попотеть не одного программиста.

25.04.2019    14195    0    m-rv    2    

Преобразование EXCEL в таблицу значений без COM и других извращений

Загрузка и выгрузка в Excel v8 1cv8.cf Бесплатно (free)

Получение таблицы значений из excel в 1С v8, без COM, внешних источников данных и т.д. EXCELВТаблицуЗначений() - За 10 строчек кода! Реализация протестирована на 1С 8.3.12.1714 (x64).

18.04.2019    23911    9    Eret1k    43    

О расширениях замолвите слово...

Практика программирования Разработка v8 Бесплатно (free)

О чём стоит задуматься при принятии решения о создании расширения конфигурации…

07.04.2019    29417    0    ellavs    126    

Git-репозитории для 1С-кода (опыт использования при небольших проектах)

Практика программирования Разработка v8 Бесплатно (free)

Инструкции по взаимодействию с Git-репозиторием, которые писались для тех наших программистов, которые вообще никогда не работали с Git (руководства в духе "Как получить код из git-репозитория?", "Как отправить код в git-репозиторий")...

28.03.2019    23083    0    ellavs    86    

Excel vs 1С: битва с неожиданным исходом Промо

Анализ учета Универсальные обработки Загрузка и выгрузка в Excel Финансовые Управленческие v8 1cv8.cf Россия Бесплатно (free)

Что лучше 1С или Excel? Разберемся, в казалось бы, очевидном, чтобы получить невероятное!

11.04.2019    33801    0    bolefirenko    116    

Трюки с внешними источниками данных

Практика программирования Разработка v8 1cv8.cf Бесплатно (free)

Некоторые трюки для преодоления ограничений внешних источников данных.

14.03.2019    26543    0    YPermitin    53    

Возможности типовых шаблонов ограничения доступа на уровне записей (RLS)

Практика программирования БСП (Библиотека стандартных подсистем) Роли и права v8 v8::Права Бесплатно (free)

Краткий обзор применения типовых шаблонов ограничения доступа на уровне записей в конфигурациях, созданных на базе БСП: #ПоЗначениям, #ПоНаборамЗначений, #ПоЗначениямРасширенный, #ПоЗначениямИНаборамРасширенный

03.02.2019    31545    0    ids79    9    

Запись одной книги Excel на нескольких листах средствами 1С (без внешних компонент)

Загрузка и выгрузка в Excel v8 1cv8.cf Бесплатно (free)

Пользователи часто просят сохранить им стопиццот отчетов в один файл Excel, чтобы отчеты были в одном файле. Ну или клиент хочет счет, накладную и счет-фактуру получить в одном документе. 1С умеет это делать без всяких там COM-объектов. Давайте разберемся, куда нажимать и что крутить.

14.01.2019    19308    0    starik-2005    25    

Как прикрутить ГУИД к регистру сведений Промо

Практика программирования Перенос данных из 1C8 в 1C8 Разработка v8 Бесплатно (free)

... и немного теории обмена данными. В частности, разберем боль всех, кто пишет небанальные обмены данными: как набору записей регистра сведений назначить гуид и далее использовать его в обмене для идентификации этого набора.

16.04.2019    17814    0    m-rv    17    

Новый подход к обмену данными EnterpriseData

Практика программирования Обмен через XML v8 v8::УФ Россия Бесплатно (free)

Хочу предложить Вашему вниманию цикл статей, посвященных обмену данными через универсальный формат (EnterpriseData или ED).

14.12.2018    35189    0    ids79    72    

Программное заполнение пользовательских параметров и отборов СКД

Практика программирования v8 v8::СКД 1cv8.cf Бесплатно (free)

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

13.11.2018    37635    0    Unk92    21    

Как сделать запрос на изменение данных Промо

Практика программирования v8 v8::Запросы 1cv8.cf Бесплатно (free)

В статье приведены особенности внутренней архитектуры и примеры работы с расширением языка запросов 1С.

01.06.2018    27448    0    m-rv    21    

Автоматические и управляемые блокировки применительно к типовым конфигурациям 1С

Математика и алгоритмы Практика программирования v8 v8::blocking 1cv8.cf Бесплатно (free)

Основные принципы работы с режимами автоматических и управляемых блокировок в 1С Предприятие 8. Теория и применение в типовых конфигурациях: БП, УТ, ЕРП

10.11.2018    30646    0    ids79    40    

Произвольный код в фоновом режиме

Практика программирования v8 1cv8.cf Бесплатно (free)

Задача: реализовать выполнение произвольного кода в фоновом режиме без изменения конфигурации, т.е. во внешней обработке.

03.09.2018    24002    0    nikita0832    42    

Основные понятия и механизмы оптимизации клиент-серверного взаимодействия в 1C

Математика и алгоритмы Практика программирования v8 Россия Бесплатно (free)

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

23.08.2018    34887    0    Rain88    46    

Метод формирования движений в типовых регистрах нетиповыми регистраторами Промо

Практика программирования v8 1cv8.cf Бесплатно (free)

Вариант решения задач с проведением по типовым регистрам нетиповыми регистраторами. Зачем - чтобы при сравнении конфигурации не обращать внимание на свойства регистров и исключить вероятность допущения горькой оплошности при обновлении информационных баз, заменив типы регистраторов основной конфигурации типами конфигурации поставщика. Для программных продуктов, имеющих в своем составе метаданных документ "Корректировка регистров"("Корректировка записей регистров").

05.12.2017    25751    0    itriot11    34    

Из Excel в 1С запросом

Загрузка и выгрузка в Excel v8 1cv8.cf Бесплатно (free)

... ну, конечно, не прям так типовым языком запросов, а расширенным языком запросов. Речь пойдет о том, как "залить" данные в таблицы 1С и не пилить при этом бесконечного количества наколеночных обработок.

14.08.2018    18743    0    m-rv    5    

Тестер: частые вопросы

Практика программирования v8 Бесплатно (free)

Ошибкам бой - тесты норма жизни!

25.07.2018    26262    0    grumagargler    26    

Повышаем эффективность разработки правил обмена

Практика программирования Перенос данных из 1C8 в 1C8 v8 КД Бесплатно (free)

Как повысить скорость и качество разработки правил обмена? Как вести групповую разработку правил обмена? Как облегчить сопровождение правил обмена после передачи в эксплуатацию? Об этом и многом другом вы можете узнать из этой статьи.

25.06.2018    26161    0    olegtymko    47    

Использование классов .Net в 1С для новичков Промо

Практика программирования Разработка внешних компонент Универсальные функции v7.7 v8 Бесплатно (free)

Руководство для новичков. Написав статью http://infostart.ru/public/238584/, я понял, что многие не понимают того, что написано. Поэтому в этой статье постараюсь более подробно остановиться на азах и без кода на вражеском языке (C#)

27.01.2016    71135    0    Serginio    108    

Введение в механизм представлений в ЗУП ред. 3

Практика программирования v8 v8::СПР ЗУП3.x Бесплатно (free)

В нашей организации на первом же телефонном собеседовании на должность разработчика по ЗУП ред. 3 вас обязательно спросят о том, что такое "Представления".

04.06.2018    34182    0    xrrg    82    

Строим графы средствами 1С (без GraphViz)

Практика программирования v8 Бесплатно (free)

Множество статей на Инфостарте описывают, как работать с компонентой GraphViz, чтобы построить ориентированный граф. Но практически нет материалов, как работать с такими графами средствами 1С. Сегодня я расскажу, как красиво строить графы с минимальным пересечением. Нам этот метод пригодился для отрисовки алгоритмов в БИТ.Финансе, т.к. типовой механизм не устраивал. Еще это может быть полезно для визуализации различных зависимостей: расчета себестоимости, графы аффилированности компаний и т.д. Надеюсь, эта статья поможет сделать мир 1С красивее и гармоничней:) Итак, поехали...

23.05.2018    22893    0    slozhenikin_com    20    

Распределение расходов пропорционально продажам

Финансовый учет и бюджетирование (FRP) Учет доходов и расходов Практика программирования Финансовый учет и бюджетирование (FRP) Учет доходов и расходов v8 v8::ОУ УТ10 УУ Бесплатно (free)

Финансовая модель. Распределение административных расходов по подразделениям пропорционально продажам за месяц. Дополнительные реквизиты против бизнес-процессов!

13.05.2018    17023    0    Rustig    9    

Просмотр временных таблиц запроса в отладчике без изменения кода

Практика программирования v8 v8::Запросы 1cv8.cf Бесплатно (free)

Данный способ можно использовать для просмотра содержимого временных таблиц запросов (менеджеров временных таблиц) без внесения изменений в код.

24.04.2018    43011    0    avfed@rambler.ru    26