[Разработчику] Любая таблица значений в OLAP

21.12.12

Разработка - Инструментарий разработчика

Анализируем различные данные в 1С, используя OLAP-технологии со всеми прелестями. Т.е. наглядное отображение данных, быстрые расчеты, горизонтальные и вертикальные группировки любой вложенности, удобная фильтрация, Drag'n'Drop и ещё много приятных вещей от MS.

Обработка на входе принимает практически любую таблицу значений (ТЗ в которой колонкам указаны типы значений, строка, число и т.п.), на выходе имеем на форме 1С сводную таблицу и график по этой ТЗ, с которой работаем, как и в Excel со сводной таблицей и диаграммой.

Взял за основу разработку «OLAP Анализ счёта» ( http://infostart.ru/public/14964/ ) от JohnyDeath и переделал под любую ТЗ.

Опционально используется «Прогресс бар для 1С 77» (http://infostart.ru/public/14061/ ) от Gmix.

Скачать файлы

Наименование Файл Версия Размер
OLAP_ТЗ.zip
.zip 39,55Kb
51
.zip 39,55Kb 51 Скачать

Требования такие же, как и у разработки «OLAP Анализ счёта» ( //infostart.ru/public/14964/ ) от JohnyDeath, т.е.:


1. Наличие предварительно загруженных внешних компонент 1С++ не ниже 2.5 (www.1cpp.ru) и FormEx (dorex.ru)
2. Определён и подключён класс "Общие.Форма.Привязка" (автор Дмитрий Ощепков ака DmitrO)
3. Установленные Office Web Components (входит в стандартную поставку Office, работа проверялась под Office XP RUS и Office 2003), отдельно компоненту без Office можно качнуть тут: http://www.microsoft.com/downloads/details.aspx?displaylang=ru&FamilyID=7287252c-402e-4f72-97a5-e0fd290d4b76
4. Драйвер доступа к данным MS Access (находится в ODBC Data Source)
5. Опционально, наличие внешней обработки прогресс бара «Прогресс бар для 1С 77» (//infostart.ru/public/14061/ ) от Gmix

Порядок установки:
1. Скачать с сайта www.1cpp.ru ВК 1с++ версии не ниже 2.5 и скопировать её в каталог ИБ.
2. Скачать с сайта http://dorex.ru/?projects&formex&download ВК FormEx версии не ниже 2.0.5 и скопировать её в каталог ИБ.
3. Скопировать в каталог ИБ файлы "defcls.prm" и "Общее.Форма.Привязка.ert"
4. В глобальный модуль в процедуру ПриНачалеРаботыСистемы вставить следующие строки:
ЗагрузитьВнешнююКомпоненту("1cpp.dll");
ЗагрузитьВнешнююКомпоненту("formex.dll");
5. Если у вас установлен Office XP, то поменяйте значение переменной "ВерсияОфис" на "10" в OLAP_ТЗ.ert (по умолчанию считается, что у вас стоит Office 2003)
6. В каталог ExtForms каталога ИБ скопировать OLAP_ТЗ.ert.
7. Опционально, скачать «Прогресс бар для 1С 77» (//infostart.ru/public/14061/ ) от Gmix и положить в каталог ExtForms каталога ИБ ProgressBar7-7.ert.

 

Использование:
1. Пример кода:

//*******************************************
Функция СоздатьТЗ(ТЗ)
   
ТЗ.НоваяКолонка("Дата","Дата");
   
ТЗ.НоваяКолонка("Значение","Число");
   
ТЗ.НоваяКолонка("Измерение1","Строка");
   
ТЗ.НоваяКолонка("Измерение2","Строка");
   
ТЗ.НоваяКолонка("Измерение3","Строка");

    Для
Сч = 1 По 100 Цикл
       
ТЗ.НоваяСтрока();
       
ТЗ.Дата = Дата(2012, 1 + Цел(Сч/10), 1);
       
ТЗ.Значение = Сч * 10;
       
ТЗ.Измерение1 = "Измерение1 - " + Строка(1 + Цел(Сч/10));
       
ТЗ.Измерение2 = "Измерение2 - " + Строка(1 + Цел(Сч/10));
       
ТЗ.Измерение3 = "Измерение3 - " + Строка(1 + Цел(Сч/10));
    КонецЦикла;

    Возврат
ТЗ;
КонецФункции   
// СоздатьТЗ

//*******************************************
Процедура Сформировать()
   
ТЗ = СоздатьОбъект("ТаблицаЗначений");
   
ТЗ = СоздатьТЗ(ТЗ);

   
спПарам = СоздатьОбъект("СписокЗначений");
   
спПарам.ДобавитьЗначение(ТЗ, "ТЗ");
   
спПарам.ДобавитьЗначение("Тест ТЗ", "Заг");
   
спПарам.ДобавитьЗначение("Тест ТЗ", "ЗагСтр");

    ОткрытьФорму(
"Обработка", спПарам, КаталогИБ()+"ExtForms\OLAP_ТЗ.ert");
КонецПроцедуры 
// Сформировать

2. Если всё прошло успешно, то можете переходить на вкладки "Сводная таблица" или "диаграмма" и наслаждаться всеми прелестями Майкрософтовской сводной таблицы.

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

См. также

Консоль запросов

Инструментарий разработчика Платформа 1С v7.7 Конфигурации 1cv7 Абонемент ($m)

Консоль запросов к базе SQL, не требующая внешних компонент

10 стартмани

29.04.2015    21528    54    Gvozdod    8    

14

StartManager 1.4 - Развитие альтернативного стартера

Инструментарий разработчика Платформа 1С v7.7 Платформа 1С v8.3 Абонемент ($m)

Очередная редакция альтернативного стартера, являющегося продолжением StartManager 1.3. Спасибо всем, кто присылал свои замечания и пожелания, и тем, кто перечислял финансы на поддержку проекта. С учетом накопленного опыта, стартер был достаточно сильно переработан в плане архитектуры. В основном сделан упор на масштабируемость, для способности программы быстро адаптироваться к расширению предъявляемых требований (т.к. довольно часто просят добавить ту или иную хотелку). Было пересмотрено внешнее оформление, переработан существующий и добавлен новый функционал. В общем можно сказать, что стартер эволюционировал, по сравнению с предыдущей редакцией. Однако пока не всё реализовано, что планировалось, поэтому еще есть куда развиваться в плане функциональности.

1 стартмани

23.04.2014    165606    1863    Alexoniq    1596    

496

Tray Informer

Инструментарий разработчика Платформа 1С v7.7 Платформа 1С v8.3 Россия Абонемент ($m)

Согласитесь, что окно стандартное сообщений в 1С иногда приносит больше неудобств, чем пользы. И тем более разные "Предупредить"... Что с этим окном только не делают! Его отцепают от формы, делают маленьким, умудряются спрятать за границы экрана. А потом звонят программистам с претензией, что документ почему-то не проводится, отя ничего и не пишет. У вас такого не было? А вот у нас было и не раз )))

1 стартмани

04.09.2013    32866    61    O-Planet    78    

49

Изменение структуры баз 1С 7.7 без долгой реструктуризации. Часть 1. Справочники

Инструментарий разработчика Платформа 1С v7.7 Конфигурации 1cv7 Абонемент ($m)

На днях встретил вопрос на форуме про возможность внесения изменений в конфигурацию без долгого сохранения в рабочей базе большого объема. Вот решил поделиться опытом, как это делал я. База у нас была объемом порядка 120 Гб. К базе обращался сайт в режиме 24/7, поэтому важно было быстро сохранять изменения и желательно без последующего монопольного запуска для восстановления индексов и процедур и без отключения пользователей от базы. Это первая часть статьи и посвящена она справочникам. С одной стороны - это самый простой объект, с другой стороны, именно про справочник спрашивалось на форуме. Если статья будет востребована, то я напишу аналогичные про документы, регистры и может еще что.

1 стартмани

13.08.2013    21180    Reptile    5    

35

v7.7 1CDialogControls: Инструмент в помощь разработчику на 7.7.

Инструментарий разработчика Платформа 1С v7.7 Конфигурации 1cv7 Абонемент ($m)

Давным давно, когда я еще плотно писал на 7.7 работа с формами была мучительной и неудобной. Приходилось каждый элемент выкладывать, выравнивать на форме ручками, прописывать код в модуле. Иногда при разработке очередной формы приходила в голову мысль: "а где-то я уже похожее делал..." и начинался мучительный поиск подходящего кода в своих запасах........

1 стартмани

21.02.2013    18023    35    MarSeN    14    

16

Библиотека кода 1С 7.7 (накопленная за 8 лет)

Инструментарий разработчика Платформа 1С v7.7 Конфигурации 1cv7 Абонемент ($m)

Весь код на 1С 7.7, собранный для повторного использования за 8 лет работы.

10 стартмани

25.11.2012    34944    248    adhocprog    51    

70

Групмейкер для таблицы значений.

Инструментарий разработчика Платформа 1С v7.7 Оперативный учет 7.7 Бухгалтерский учет 7.7 Расчет 7.7 Конфигурации 1cv7 Абонемент ($m)

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

1 стартмани

20.11.2012    30653    59    dusha0020    15    

24
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. Ish_2 1104 21.12.12 15:34 Сейчас в теме
Где пропадал ?
А мы уже на 1с8 перешли..
Yan_Malyakov; +1 Ответить
2. venger 2121 21.12.12 16:04 Сейчас в теме
(1) Та, работа, дом и т.п.
Вы не поверите сколько еще используют 7.7;-) Но одно другому не мешает, восемь тоже буит;-)
4. kapustinag 22.12.12 09:50 Сейчас в теме
(2)
Заголовок и начало прочитал, облизнулся уже, и тут увидел, что для 7.7. Если для 8 действительно будет - будет здорово. Посмотреть версию для 7.7 не могу, но плюс все-равно поставлю, в ожидании версии для 8.
6. Yashazz 4707 23.12.12 20:17 Сейчас в теме
(4) А что, СКД уже не хватает? Многие фишки СКД вполне позволяют говорить о ней как об R-ROLAP, и зачем изобретать велосипеды? Это вот на 7.7 да, тяжко.
3. v_id 106 21.12.12 21:46 Сейчас в теме
А если офис старше 2003 как работать заставить?
5. venger 2121 22.12.12 12:14 Сейчас в теме
(3) Можно и вообще без офиса, только поставить веб-компоненту Office, OWC11.EXE, ссылка в описании. Соответственно, попробуйте ее накатить, если стоит другой офис или вообще не стоит
Оставьте свое сообщение