0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

kintone で検索クエリを実行する Python プログラム

Last updated at Posted at 2025-03-26

kintone で検索クエリを実行する Python プログラムを作りました。
今回は API トークンを使っています(ユーザー名/パスワードではなく)。

(PHP版は curl を使わないとできなさそうだったので、あきらめました。)

実行

python 41_get_records_query.py

検索クエリ実行

41_get_records_query.py
import base64
import urllib.request
import json
from pathlib import Path

appno = 123 # APIトークンも切替え必要
#appno = 124 # APIトークンも切替え必要

uri = "https://sample.cybozu.com/k/v1/records.json"

binary_bytes = base64.b64decode("abcabcabcabcabcabcabcabcabcabcabcabc")
#binary_bytes = base64.b64decode("defdefdefdefdefdefdefdefdefdefdefdef")

binary_string = binary_bytes.decode('latin1')

headers = {
    "X-Cybozu-API-Token": binary_string,
    "Content-Type": "application/json",
}

body = {
    "app": appno,
    "query": '印刷 not in ("確認")' # チェックボックス
#    "query": '作成日時 >= "2024-10-01"' # 作成日時
#    "query": '氏名 = "鈴木太郎"' # 文字列(1行)の設定
#    "query": 'レコード番号 <= 456 and 印刷 not in ("確認") limit 500' # AND条件

}

req = urllib.request.Request(
            url=uri,
            data=json.dumps(body).encode(),
            headers=headers,
            method="GET",
            )

response = urllib.request.urlopen(req)
res_dict = json.load(response)

# JSON を整形して表示する
#print(json.dumps(res_dict, indent=4, ensure_ascii=False))

# 「TBL_製品情報_商品名_バーコード」の value を抽出
for record in res_dict.get("records", []):
    case_no = record.get("問合せ番号", {}).get("value")
    record_no = record.get("レコード番号", {}).get("value")
    created_by = record.get("作成者", {}).get("value", {}).get("name")
    created_time = record.get("作成日時", {}).get("value")
    updated_by = record.get("更新者", {}).get("value", {}).get("name")
    updated_time = record.get("更新日時", {}).get("value")

    #print(f"問合せ番号: {case_no}|レコード番号: {record_no}|作成者: {created_by}|作成日時: {created_time}|更新者: {updated_by}|更新日時: {updated_time}")

    for row in record.get("TBL_製品情報", {}).get("value", []):
        bar_code = row["value"].get("TBL_製品情報_商品名_バーコード", {}).get("value")
        print(f"問合せ番号: {case_no}|バーコード: {bar_code}|レコード番号: {record_no}|作成者: {created_by}|作成日時: {created_time}|更新者: {updated_by}|更新日時: {updated_time}")

 
出力例(レコード単位で)

問合せ番号: 202501_00001|レコード番号: 345|作成者: 鈴木太郎|作成日時: 2025-01-25T01:10:00Z|更新者: 鈴木太郎|更新日時: 2025-01-25T01:10:00Z
問合せ番号: 202501_00002|レコード番号: 346|作成者: 鈴木太郎|作成日時: 2025-01-25T01:11:00Z|更新者: 鈴木太郎|更新日時: 2025-01-25T01:11:00Z

 
以下のように変更すると、レコードの一括更新も可能です。

body = {
    "app": appno,
    "records": [

      {
        "id": "345",
        "record": {
          "印刷": {
            "value": [
              "確認",
            ],
          },
        },
      },
      {
        "id": "346",
        "record": {
          "印刷": {
            "value": [
              "確認",
            ],
          },
        },
      },


            method="PUT",


# JSON を整形して表示する
print(json.dumps(res_dict, indent=4, ensure_ascii=False))


 
以下は、一括更新用のデータを作るための、テキスト変換プログラムです。

実行
python CreateData.py > update_records_list.txt
CreateData.py
import re

# 入力ファイルパス
input_file = "output_records_list.txt"

with open(input_file, "r", encoding="utf-8") as f:
    for line in f:
        match = re.search(r"レコード番号: (\d+)", line)
        if match:
            record_id = match.group(1)
            output = (
                "      {\n"
                f'        "id": "{record_id}",\n'
                "        \"record\": {\n"
                "          \"印刷\": {\n"
                "            \"value\": [\n"
                "              \"確認\",\n"
                "            ],\n"
                "          },\n"
                "        },\n"
                "      },"
            )
            print(output)

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?