スキップしてメイン コンテンツに移動

Google Spread Sheetの利用

 


以前にESP32で作っていたものを、Raspberry Pi Pico W + MicroPythonで再現してみました。

1.Googleスプレッドシートの設定

1.Google Drive → 右クリック → Google スプレッドシート

2.作成して共有をクリック


3.任意の名前を変更


4.拡張機能→Apps Script
スクリーンショット 2025-04-19 161622

5.プロジェクト名を変更し、下記コードを入力します。

/**
 * HTTP GETリクエストを処理する関数
 * 指定されたGoogleスプレッドシートにリクエストのパラメータを記録します。
 *
 * @param {Object} e - イベントオブジェクト(リクエストパラメータを含む)
 * @return {ContentService.Output} - 成功メッセージを返します。
 */
function doGet(e) {
  // データを保存する「3で作成したGoogleスプレッドシートのURL」を指定
  const url = "";

  // URLを使ってスプレッドシートを開く
  const ss = SpreadsheetApp.openByUrl(url);

  // スプレッドシート内の最初のシートを取得
  const sheet = ss.getSheets()[0];

  // HTTP GETリクエストで送られたパラメータを取得
  // パラメータ名 A1, B1, C1 に対応する値を取得
  const A1 = e.parameter.A1; // リクエストパラメータ "A1"
  const B1 = e.parameter.B1; // リクエストパラメータ "B1"
  const C1 = e.parameter.C1; // リクエストパラメータ "C1"

  // 現在の日時を取得してタイムスタンプを作成
  const timestamp = new Date();

  // シートの最後に新しい行を追加(タイムスタンプとパラメータの値を記録)
  sheet.appendRow([timestamp, A1, B1, C1]);

  // レスポンスとして "success" を返す
  return ContentService.createTextOutput('success');
}

6.右上のデプロイから新しいデプロイをクリック


7.種類の設定マーク→ウェブアプリをクリック

deploy_AA.jpg

8.次のユーザーとして実行は、自分のメールアドレス

  アクセスできるユーザー:全員

  デプロイをクリックします
deploy_BB.jpg

9.データへのアクセスを許可するために、アクセスを承認をクリックしてください。

shounin_deploy.jpg

10.アカウントの選択で、該当する「アカウント」を選びます。

11.左下のAdvanced(詳細)をクリックしてください。

google_dep_DD.jpg
12.次に警告が出るので、Go to PicoW-tempCSV (unsafe)に移動 をクリックしてください。


13.Pico WからGoogleドライブへのアクセスリクエストを許可してください。


14.以下のポップアップ画面が表示され、今回作成した「ウェブアプリ固有のURL」が発行されるので、URLをコピーして完了をクリックしてください。

google_dep_GG.png

2.ソースコード(Pico w側)


import network
import urequests
import time
import random

# ★変更要:Wi-Fi情報
SSID = ''         # 例: 'MyWiFi'
PASSWORD = ''     # 例: 'password1234'

# ★変更要:Google Apps ScriptのURL
BASE_URL = ''     # 例: 'https://script.google.com/macros/s/xxxxx/exec'

# Wi-Fi接続関数
def connect_wifi(ssid, password):
    wlan = network.WLAN(network.STA_IF)
    wlan.active(True)
    wlan.disconnect()
    wlan.connect(ssid, password)

    print("Connecting to WiFi", end="")
    timeout = 10  # 最大10秒待機
    for i in range(timeout):
        if wlan.isconnected():
            print("\nConnected!")
            print("IP address:", wlan.ifconfig()[0])
            return True
        print(".", end="")
        time.sleep(1)
    print("\nFailed to connect to WiFi.")
    return False

# データ送信関数
def send_to_google_sheet(url, a1, b1, c1):
    final_url = f"{url}?A1={a1}&B1={b1}&C1={c1}"
    print("Generated URL:")
    print(final_url)

    try:
        response = urequests.get(final_url)
        print("HTTP Status Code:", response.status_code)
        print("Payload:", response.text)
        response.close()
    except Exception as e:
        print("Request failed:", e)

# メイン処理
def main():
    if connect_wifi(SSID, PASSWORD):
        # ランダムな値を生成
        a1 = random.randint(20, 30)
        b1 = random.randint(40, 60)
        c1 = random.randint(70, 90)

        print("Sending data to Google Spreadsheet:")
        print(f"A1: {a1}, B1: {b1}, C1: {c1}")

        send_to_google_sheet(BASE_URL, a1, b1, c1)

# 実行
main()




【実行結果】

コメント

このブログの人気の投稿

Raspberry Pi Pico Wを使ってみよう

   Raspberry Pi Pico W(ラズベリーパイ ピコ ダブリュー) は、英国 Raspberry Pi 財団が 2022 年に発売した Wi-Fi 搭載マイコンボードです。従来の「Raspberry Pi」と聞くと Linux が動くシングルボードコンピュータ(SBC)を思い浮かべがちですが、Pico W は マイクロコントローラ (MCU)に分類され、いわゆる “組み込み開発” を手軽に始められるデバイスです。搭載 MCU はデュアルコア Arm Cortex-M0+(133 MHz 動作)の RP2040 。ここに Infineon 製 CYW43439 チップが追加され、 2.4 GHz IEEE 802.11 b/g/n Wi-Fi(BLE 対応 FW も提供中) が使えるのが最大の特徴です。  開発言語は MicroPython や CircuitPython が真っ先に紹介されることが多いのですが、 公式 Pico SDK を使えば C/C++ でも本格的に開発 できます。SDK は CMake ベースで Windows/macOS/Linux いずれでも利用可能。さらに、Arduino Core RP2040 が整備されたことで Arduino IDE 2.x からも “スケッチ感覚” で書き込みが可能 になりました。したがって、 「まずは Python でサッと試す」 「より高速化や省メモリ化が必要になったら C/C++ へ移行」 といった二段構えの学習ルートが取れるのが魅力です。 メニュー(基礎編) 01. Raspberry Pi Pico Wの開発環境を整える。 02. スイッチで 発光ダイオード(LED) を点灯・消灯させる 03. タイマーで発光ダイオード(LED)を1秒ごとに点滅させる 04. シリアル通信(オウム返し ) 05. シリアル通信(発光ダイオードの点灯・消灯) 06. サーボモーターを動かしてみよう(SG90制御入門) 07. DCモータを動かす(PWM) 08. IRリモートでRGBLED点灯 09. アナログ電圧を測定する(ADCの基本) 10. GPIO割り込み処理 11. リレーを駆動してLEDを制御する 12. DFPlayer で MP3 再生 13. 7 セグ 4 ...

スイッチで発光ダイオード(LED)を点灯・消灯させる

 スイッチを使って発光ダイオード(LED)を制御してみましょう。今回は、スイッチをオンにすると LED が点灯し、オフにすると消灯するように動作させます。もちろん、スイッチと LED を直接接続するのではなく、適切な回路を介して制御します。 1.回路 GPIO16 はデジタル入力として使用し、内部プルアップを有効にします。GPIO15 は出力として設定します。なお、接続には 1kΩ(1キロオーム)の抵抗を使用します。 【ソースコード】 # スイッチで LED を ON / OFF する簡単な例 #   GPIO15 : LED(出力)— LOW で消灯、HIGH で点灯 #   GPIO16 : スイッチ(入力)— 内部プルアップ抵抗を使用 # # ※ 配線例 #   LED のアノード → 1 kΩ 抵抗 → GPIO15 #   LED のカソード → GND #   スイッチ片側   → GPIO16 #   スイッチ反対側 → GND # # ★ 動作 #   スイッチを押す(GPIO16 が LOW)   → LED 点灯 #   スイッチを離す(GPIO16 が HIGH) → LED 消灯 from machine import Pin    # GPIO 制御ライブラリ import utime               # 時間関連(今回は使用しないが拡張用に読み込み) led = Pin ( 15 , Pin.OUT)                 # GPIO15 を出力モードに設定(LED 用) sw   = Pin ( 16 , Pin.IN, Pin.PULL_UP)     # GPIO16 を入力モード+内部プルアップ有効 while True:     if sw. value () == 1 :      # プルアップなので押していないときは 1   ...

シリアル通信(オウム返し)

 Raspberry Pi Pico Wは単体で使うのも便利ですが、パソコンや他のマイコンなど、さまざまな機器と通信できるとさらに活用の幅が広がります。 そこで今回は「シリアル通信」について紹介します。 まずは、パソコンから送られてきたデータをPico Wが受け取り、同じデータをそのままパソコンに送り返す、いわゆる「オウム返し(エコー)」を実装してみましょう。 シリアル通信とは? シリアル通信は、マイコンとパソコンや他の機器がデータを1ビットずつ順番に送受信する通信方式です。Raspberry Pi Pico WではUART(Universal Asynchronous Receiver/Transmitter)というハードウェアを使って実現します。 接続回路  id      TX       RX        baudrate     parity    stopbit  0  GPIO0 GPIO1   9600  なし  1  1  GPIO4 GPIO5   9600  なし  1 今回はUART1(GPIO4:TX、GPIO5:RX)を使用します。 ソースコード例 from machine import UART, Pin # UART1ポートを9600bpsで初期化(ボーレートを指定) sirial = UART ( 1 , 9600 ) # UARTの詳細設定: 9600bps 、データビット8、パリティ無し、ストップビット1で初期化 sirial. init ( 9600 , bits = 8 , parity = None, stop = 1 ) # UARTで文字列を送信する(※MicroPythonではバイト列で送るのが正しいため b '' にしたほうが安全) sirial. write (b 'Hello World \n\r ' )  # 起動時に「Hello World」を送信 # メインループ while True:     # 受信バッファにデータが存在するかチェック     if sirial. any () > 0 : ...