![]() 307 / 248 / 40
Регистрация: 28.09.2013
Сообщений: 600
|
|
Декомпрессия тэгов WinCC02.07.2018, 19:10. Показов 3135. Ответов 10
Метки нет Все метки)
(
Доброго времени суток, коллеги!
Подскажите пожалуйста, как можно провести декомпрессию тэгов из БД WinCC в человеческий вид. Вопрос аналогичен этому, однако в той теме ссыли в ответе почему-то не работают((( Глобальная задача заключается в записи "расжатых" данных на другой сервер для объединения с большим количеством других переменных с целью совместного анализа. P.S.: до этого не сталкивался с WinCC на таком уровне
0
|
02.07.2018, 19:10 | |
Ответы с готовыми решениями:
10
Декомпрессия текста |
![]() 307 / 248 / 40
Регистрация: 28.09.2013
Сообщений: 600
|
|
04.07.2018, 20:05 [ТС] | |
интересует именно такой вариант)
выборку сделать я смогу. Наиболее животрепещущий вопрос - как трансформировать BinData в нормальные числа. То есть по сути меня интересует спецификация сжатия данных - как развернуть Bin в человеческие значения.
0
|
![]() 307 / 248 / 40
Регистрация: 28.09.2013
Сообщений: 600
|
|
04.07.2018, 20:57 [ТС] | |
vxg, пишет их приложение, собирающее данные с семёновских PLC
Сохранение идет в базу данных. Там есть несколько таблиц, в частности TagCompressed и TagDecompressed, причем декомпрессированная пустая. Почитав на просторах шайтан-тырнета я пришел к выводу, что запись в виде TagCompressed является стандартной для ПЛК Сименса на комп через WinCC. Ссыль на общий вид таблицы БД в первом посте. Очевидно, данные каким-то образом сжимаются, вот никак не могу найти спецификацию, чтобы руками распарсить BinData. P.S.: Прогу писали наши китайские друзья, след которых простыл давным-давно, документации и описания само-собой не осталось, даже на китайском. Программа забирает около 200 датчиков через кучу ПЛК и пишет их на сервер в виде файлов mdf с определенным периодом (или объемом, ХЗ). Добавлено через 3 минуты Видимо нужно что-то вроде этого Ну, или спецификация формата сжатия)))
0
|
Модератор
![]() 3401 / 2172 / 353
Регистрация: 13.01.2012
Сообщений: 8,429
|
|||||||||||
05.07.2018, 21:13 | |||||||||||
![]() Решение
Winney, можно вытаскивать их средствами WinCC и сохранять в удобной форме
что то вроде этого (достал из чулана, точно не уверен) на листе Excel пишем
1
|
![]() 307 / 248 / 40
Регистрация: 28.09.2013
Сообщений: 600
|
|
05.07.2018, 22:57 [ТС] | |
vxg, спасибо большое! Постараюсь это раскурить.
З.Ы.: "Держатели" данных считают, что крутить на сервере че-то и вообще дышать на него перегаром совершенно недопустимо. Поэтому я рассматриваю вариант копирования файлов mdf на другой сервер (посредством флэшки, например) и их обработку уже там. Еще раз на всякий случай поинтересуюсь - не описан ли где способ декомпрессии тэгов вручную? Ну что-то вроде: первые столько-то байт - данные такие-то, последующие 8 байт - данные другие-то, и т.д.
0
|
Модератор
![]() 3401 / 2172 / 353
Регистрация: 13.01.2012
Сообщений: 8,429
|
|
06.07.2018, 07:43 | |
Winney, однозначно такой способ есть и я думаю он достаточно прост, но официальной документации мне не встречалось, использовать догадки не стал - есть вероятность не увидеть какие-то исключительные ситуации или попасть на обновление распаковщика
1
|
06.07.2018, 15:21 | |
Этот способ прекрасно работает. Используя поставщик данных WinCCOLEDBProvider можно получить доступ к архивным данным WinCC без самостоятельной распаковки и ковыряния стандарта компрессии. И если у вас уже есть лицензия на WinCC, то еще и бесплатно.
1
|
06.07.2018, 15:21 | ||||||
Помогаю со студенческими работами здесь
11
Декомпрессия данных Декомпрессия GZIP ответа Компрессия и декомпрессия RLE httpwebrequest cookies и декомпрессия Компрессия и декомпрессия RLE Искать еще темы с ответами Или воспользуйтесь поиском по форуму:
|
|
Новые блоги и статьи
![]() |
||||
Результаты исследования от команды MCM (март 2025 г.)
Programma_Boinc 07.04.2025
Результаты исследования от команды MCM (март 2025 г. )
В рамках наших текущих исследований мы продолжаем изучать гены, которые имеют наибольшую вероятность развития рака легких, выявленные в рамках. . .
|
Рекурсивные типы в Python
py-thonny 07.04.2025
Рекурсивные типы - это типы данных, которые определяются через самих себя или в сочетании с другими типами, которые в свою очередь ссылаются на исходный тип. В мире программирования такие структуры. . .
|
C++26: Объединение и конкатенация последовательностей и диапазонов в std::ranges
NullReferenced 07.04.2025
Работа с последовательностями данных – одна из фундаментальных задач, с которой сталкивается каждый разработчик. C++ прошел длинный путь в эволюции средств для манипуляции коллекциями – от. . .
|
Обмен данными в микросервисной архитектуре
ArchitectMsa 06.04.2025
Когда разработчики начинают погружаться в мир микросервисов, они часто сталкиваются с парадоксальным правилом: "два сервиса не должны делить один источник данных". Эта мантра звучит повсюду в. . .
|
PostgreSQL в Kubernetes: Автоматизация обслуживания с CNPG
Mr. Docker 06.04.2025
Администраторы баз данных сталкиваются с целым рядом проблем при обслуживании PostgreSQL в Kubernetes: как обеспечить правильную репликацию данных, как настроить автоматическое переключение при. . .
|
Async/await в TypeScript
run.dev 06.04.2025
Асинхронное программирование — это подход к разработке программного обеспечения, при котором операции выполняются независимо друг от друга. В отличие от синхронного выполнения, где каждая последующая. . .
|
Многопоточность в C#: Синхронизация потоков
UnmanagedCoder 06.04.2025
Многопоточное программирование стало неотъемлемой частью разработки современных приложений на C#. С появлением многоядерных процессоров возможность выполнять несколько задач параллельно значительно. . .
|
TypeScript: Классы и конструкторы
run.dev 06.04.2025
TypeScript, как статически типизированный язык, построенный на основе JavaScript, привнес в веб-разработку новый уровень надежности и структурированности кода. Одним из важнейших элементов этой. . .
|
Многопоточное программирование: Rust против C++
golander 06.04.2025
C++ существует уже несколько десятилетий и его поддержка параллелизма постепенно наращивалась со временем. Начиная с C++11, язык получил стандартную библиотеку для работы с потоками, а в последующих. . .
|
std::vector в C++: от основ к оптимизации производительности
NullReferenced 05.04.2025
Для многих программистов знакомство с std::vector происходит на ранних этапах изучения языка, но между базовым пониманием и подлинным мастерством лежит огромная дистанция. Контейнер std::vector. . .
|