(追記)2024/11/10 1次合格してしました!
予算:約1.8万円
プライベートや仕事で気づいたことやノウハウなどを書き留めるブログです
Google ドライブのスプレッドシートにアクセスするための認証情報を取得したいです。Google Cloud プロジェクトを作成し、API を有効する手順を教えてください
Google ドライブのスプレッドシートにアクセスするためには、Google Cloud プロジェクトを作成し、API を有効化してから認証情報を取得する必要があります。以下に手順を示します:Google Cloud プロジェクトの作成と API の有効化:Google Cloud Console にログインします(https://console.cloud.google.com/)。右上の「プロジェクトを作成」ボタンをクリックして、新しいプロジェクトを作成します。プロジェクト名を入力し、適切な組織を選択します。プロジェクトが作成されたら、左上のプロジェクト名の横にあるメニューアイコンをクリックし、ダッシュボードに移動します。「API とサービス」 > 「ライブラリ」を選択して、利用したい API を検索します。ここでは「Google Sheets API」を検索し、有効にします。認証情報の作成:ダッシュボードから「API とサービス」 > 「認証情報」を選択します。「認証情報を作成」ボタンをクリックして、サービス アカウント キーを作成します。サービス アカウント名を入力し、役割として「プロジェクト」 > 「エディター」を選択します。その他の設定は必要に応じて調整できます。「次へ」をクリックし、キーのタイプとして JSON を選択します。これにより JSON ファイルが生成されます。「作成」ボタンをクリックして、JSON ファイルをダウンロードします。JSON ファイルの保存と使用:ダウンロードした JSON ファイルをスクリプトがあるディレクトリに移動します。スクリプト内で、JSON ファイルのファイル名を使用して認証情報を読み込むコードを記述します。例えば:pythonCopy codefrom oauth2client.service_account import ServiceAccountCredentialscredentials = ServiceAccountCredentials.from_json_keyfile_name('YOUR_JSON_FILE.json', ['https://spreadsheets.google.com/feeds', 'https://www.googleapis.com/auth/drive'])gspread ライブラリを使用して Google ドライブに接続し、スプレッドシートを操作するコードを記述します。以上の手順に従って、認証情報を取得し、スクリプト内で使用することで、Google ドライブのスプレッドシートにアクセスできるようになります。
■ダウンロードしたjsonを確認
1)ファイルパス >アクセスするときにpythonコードに記載
2)メールアドレス >スプレッドシートにアクセス権を付与
ex)prjspr@prjspr.iam.gserviceaccount.com みたいなアドレスがjsonファイル内にある
■Googleドライブにスプレッドシートを作成
前述のメアドに編集権を追加する
■VScodeに書き込んで実行
import requests
import json
import gspread
from google.oauth2 import service_account
# Google ドライブの認証情報のJSONファイルを指定
credentials = service_account.Credentials.from_service_account_file('C:/Users/tmp/prjspr-12345678.json', scopes=['https://www.googleapis.com/auth/spreadsheets'])
# Google ドライブに接続
client = gspread.authorize(credentials)
# スプレッドシートのキーを指定
spreadsheet_key = 'KEY'
#ウェブアクセスの情報設定
url = 'https://webconnect.yourdata.example/dataconn/'
headers = {
'aaa': '2023-08-21'
}
data = {
"bbb": "ccc"
}
response = requests.post(url, headers=headers, json=data)
json_data = response.json()
# Google ドライブのスプレッドシートを開く
spreadsheet = client.open_by_key(spreadsheet_key)
worksheet = spreadsheet.get_worksheet(0) # ワークシートを選択
# ヘッダーを書き込む
header_values = [["Order ID", "itemno", "amount"]]
worksheet.update('A1', header_values)
# 注文データをワークシートに書き込む
row = 2 # ヘッダーの下から行を開始
for order in json_data.get("orders", []):
order_id = order.get("id")
for line_item in order.get("line_items", []):
variation_name = line_item.get("variation_name")
gross_amount = line_item.get("gross_amount", {}).get("amount")
worksheet.update(f'A{row}', order_id)
worksheet.update(f'B{row}', variation_name)
worksheet.update(f'C{row}', gross_amount)
row += 1
print("Data has been saved to the Google Sheet.")
add-type -path "c:\00lib\system.runtime.compilerservices.unsafe.6.0.0\lib\net461\System.Runtime.CompilerServices.Unsafe.dll";
add-type -path "c:\00lib\system.memory.4.5.3\lib\netstandard2.0\System.Memory.dll";
add-type -path "c:\00lib\system.valuetuple.4.5.0\lib\net461\System.ValueTuple.dll"
add-type -path "c:\00lib\System.Buffers.4.5.1\lib\net461\System.Buffers.dll";
add-type -path "c:\00lib\system.numerics.vectors.4.5.0\lib\net46\System.Numerics.Vectors.dll";
try
{
add-type -path "c:\00lib\opencvsharp4.4.7.0.20230115\lib\net48\OpenCvSharp.dll";
}
catch [System.Reflection.ReflectionTypeLoadException]
{
Write-Host "Message: $($_.Exception.Message)"
Write-Host "StackTrace: $($_.Exception.StackTrace)"
Write-Host "LoaderExceptions: $($_.Exception.LoaderExceptions)"
}
$size = New-Object OpenCvSharp.Size(240, 240) ;
$img = [OpenCvSharp.Mat]::new($size, [OpenCvSharp.MatType]::CV_8UC3, 1) ;
for ([int]$y = 0; $y -lt $img.Height; $y++)
{
for ([int]$x = 0; $x -lt $img.Width; $x++)
{
$pic = [OpenCvSharp.Vec3b]::new(255,80,3+$x);
$img.Set($x, $y, $pic);
}
}
[OpenCvSharp.Cv2]::NamedWindow("window") ;
[OpenCvSharp.Cv2]::ImShow("window", $img) ;
[OpenCvSharp.Cv2]::WaitKey();
[OpenCvSharp.Cv2]::DestroyWindow("window") ;