Оглавление:
2025 Автор: John Day | [email protected]. Последнее изменение: 2025-01-13 06:58
В этом блоге мы собираемся отправлять показания датчика SHT25 в таблицы Google с помощью Adafruit huzzah ESP8266, который помогает отправлять данные в Интернет.
- Отправка данных в ячейку таблицы Google - очень полезный и простой способ сохранить данные в табличной форме в Интернете.
- Вместо того, чтобы использовать какой-либо специальный мост, например, толкать ящик или MQTT NODE RED или любой другой тип REST API, мы собираемся отправлять данные с помощью скрипта Google, который легко получает данные от датчика, используя ссылку на скрипт, предоставленную приложение google script после публикации
- Мы можем использовать скрипт для отправки данных из таблицы Google, документов или даже на диск Google.
- Просто не заканчивайте здесь, вы можете подключить листы Google к любому веб-приложению, которое обменивается данными с пользователями так, как они хотели.
- Никаких дополнительных сборов, в отличие от других онлайн-серверов здесь, не требуется, и вы можете хранить данные до 10 ГБ максимум в учетной записи пользователя и можете использовать
- Один из лучших способов - вы можете легко научиться подключать данные к Интернету с помощью такого рода приложений реального времени.
- Мы собираемся использовать соединение I2C, которое выполняет протокол ведущий-ведомый для гибкого обмена данными с таблицами Google.
- Платформа протокола I2C соединяет аппаратное обеспечение датчика и одновременно работает примерно с 256 датчиками, используя только 2 проводных подтягивания для передачи данных датчика на 8-битном оборудовании.
Шаг 1. Аппаратное обеспечение
Наборы Adafruit Feather HUZZAH
Доска Adafruit Feather Huzzah
Встроенный адаптер Adafruit I2C и USB-адаптер
Датчик температуры и влажности SHT25
Кабель I2C
Шаг 2: Как работает материал
Получение показаний датчиков в реальном времени через ESP8266 и отправка данных на различные облачные платформы очень просто.
Мы собираемся использовать библиотеку Wire.h в Arduino IDE для создания двухпроводной связи между Adafruit Huzzah Board и модулем I2C датчика SHT25 и кабелем I2C.
Примечание. Чтобы избежать сложной структуры проводки, я собираюсь использовать адаптер I2C для Adafruit Huzzah, предназначенный для подключения датчика I2C.
Чтобы новичок мог настроить Esp8266, вы должны пройти настройку ESP8266.
Сначала инициализируйте библиотеки:
- Библиотека проводов
- ESP8266Wi-Fi
- WiFiClientSecure
Шаг 3: процесс выполнения модуля I2C в среде Arduino IDE
После инициализации библиотек мы определим процесс I2C, который будет использоваться для получения показаний датчика, преобразования их и сдвига 8-битных данных в соответствии с требованиями:
Инициализировать регистры в двухпроводном протоколе I2C для модуля датчика I2C
#define Addr 0x40
- Запустите передачу I2C, инициализируйте регистры и запросите 2 байта данных, откуда мы будем читать данные датчика.
- Если будут доступны 2 байта данных, прочтите данные датчика и, используя указанные ниже формулы, мы преобразуем желаемые значения.
плавающая влажность = (((данные [0] * 256.0 + данные [1]) * 125.0) / 65536.0) - 6;
float cTemp = (((данные [0] * 256.0 + данные [1]) * 175.72) / 65536.0) - 46,85;
float fTemp = (cTemp * 1.8) + 32;
Распечатайте значения на экране монитора последовательного порта
Шаг 4. Подключение ESP8266 к Wi-Fi и электронной таблице Google
После выполнения модулей I2C мы узнаем, как получать данные и с помощью библиотек WiFi и идентификатора хоста, а также ключей API для отправки данных в таблицы Google.
- Определите учетные данные Wi-Fi глобально в ESP8266, что поможет нам подключить плату к Интернету.
- Поскольку мы собираемся использовать HTTP-клиент и будем определять протокол HTTPS = 443 для защиты пути HTTP, поскольку сценарий будет работать только с безопасным путем.
- Инициализировать данные хоста в коде
const char * host = "script.google.com";
const int httpsPort = 443;
Строка SCRIPT_ID = "укажите идентификатор сценария, указанный в снимках";
Примечание. Идентификатор скрипта упоминается в «URL-адресе веб-приложений», в то время как код Gscript будет опубликован, просто скопируйте и вставьте идентификатор, указанный ниже, и инициализируйте его в приведенных выше командах
- Также, используя volatile с переменной, мы собираемся инициализировать переменную глобально, которая извлекает данные из модуля I2C и отправляет их в URL-скрипт, который затем отправит данные в пункт назначения.
- Используя ESP8266 WiFi Library, мы сможем подключить плату к Интернету.
- Данные датчика будут размещаться на локальном сервере каждые 5 секунд.
- С помощью URL-скрипта данные будут размещаться на опубликованной ссылке Google script Active page каждые 15 секунд.
Шаг 5. Автоматизируйте таблицу Google с помощью редактора GScript
Поскольку у всех нас есть учетная запись Google для входа в таблицу Google с помощью своей учетной записи
- Укажите значения, которые вам нужно получить от датчика, подключенного к ESP8266.
- Перейдите в Инструменты> Редактор скриптов.
- Используйте функцию «Doget» для получения событий
- В функции «Doget» для инициализации ключа API электронной таблицы, а также для подключения активного листа, на который вы хотите отправить значения датчиков.
- С помощью функции автоматизации, упомянутой в коде, можно легко представить данные в строках и столбцах.
- Наконец, сохраните данные и нажмите «Опубликовать» >> Нажмите «Развернуть как веб-приложения».
- Убедитесь, что всякий раз, когда будут какие-либо изменения, выберите «версия проекта» >> «Новый» >> нажмите «обновить».
Текущий URL-адрес веб-приложения будет выглядеть следующим образом:
script.google.com/macros/s/[GScript ID »/ exec:
далее используется в коде ESP8266 для получения данных с датчиков
Соединения с хостингом Мы собираемся использовать запрос HTTPS Get для подключения данных к идентификатору хоста, указанному в редакторе gscript, где мы дополнительно кодировали наши данные для подключения к листу Google.
функция doGet (e) {Logger.log (JSON.stringify (e)); // просмотр параметров var result = 'Ok'; // предполагаем успех if (e.parameter == 'undefined') {result = 'No Parameters'; } еще {var sheet_id = ''; // Идентификатор электронной таблицы var sheet = SpreadsheetApp.openById (sheet_id).getActiveSheet (); var newRow = sheet.getLastRow () + 1; var rowData = ; } Logger.log (JSON.stringify (rowData)); // Записываем новую строку ниже var newRange = sheet.getRange (newRow, 1, 1, rowData.length); newRange.setValues ([rowData]); }
Шаг 6: Ограничения:
- Этот проект ограничен только хранением данных датчика I2C в таблицах Google.
- Мы используем запрос HTTPS GET для получения значений через функции I2C.
- Нам нужно изменить значение в строковом формате, а затем отправить данные по URL-ссылке gscript.
Шаг 7: код, кредиты, ссылка
Код на Github:
github.com/varul29/SHT25_GoogleSheets_Goog…
Ссылка
Код I2C:
Руководство Google Script:
Встроенный магазин:
Блог с учебными пособиями: