invox API ドキュメント (1.7.0)

Download OpenAPI specification:Download

invox の REST API の仕様のドキュメントです。

ご不明な点は チャット もしくは メール にてご連絡ください。

認証仕様

APIエンドポイント

https://api.invox.jp/api/public/

  • 認証方法
    OAuth2.0 ( https://oauth.net/2/ )
    認可を経て発行されたアクセストークンを使用してinvoxの機能を利用することができます。(手順の概要)

認可エンドポイント

https://api.invox.jp/oauth2/authorize/
リクエストメソッド: GET
認可コードを取得するために使用します。(認可コードはトークンの取得に必要です)

パラメータ

名前 内容
response_type レスポンスタイプ。code を指定します。
client_id クライアントID。弊社から発行いたします。
redirect_uri コールバックURI。認可レスポンスをリダイレクトするURLです。
state クライアントが初期リクエストに追加する OPAQUE 値。認可サーバはクライアントにリダイレクトして戻るときに、この値を含めます。
scope 認可される権限。利用されるAPIによって異なります。

リクエストイメージ

GET https://api.invox.jp/oauth2/authorize/?
response_type=code&
client_id=CLIENT_ID&
redirect_uri=https://YOUR_APP/REDIRECT_URI&
state=STATE&
scope=read write

レスポンス内容

HTTP/1.1 302 Found
Location: https://YOUR_APP/REDIRECT_URI?code=AUTHORIZATION_CODE&state=STATE

※認可コード(AUTHORIZATION_CODE)の有効期限は1分間であるため、取得後、1分以内にトークンを取得する必要があります。

トークンエンドポイント(トークンの取得、リフレッシュ、取り消し)

  • トークンの取得
    https://api.invox.jp/oauth2/token/
    リクエストメソッド: POST
    トークンの初回取得に使用します。

    ヘッダー

    • Authorization
      Basic Base64Encode(CLIENT_ID:CLIENT_SECRET)
      クライアントIDとクライアントシークレットをコロン(:)でつないだ文字列をBase64でエンコードした値を、ベーシックHTTP認証を介して認証ヘッダー(Authorization)に渡します。
      クライアントID(CLIENT_ID)およびクライアントシークレット(CLIENT_SECRET)は弊社から発行いたします。
    • Content-Type
      application/x-www-form-urlencoded

    パラメータ

    名前 内容
    grant_type 付与タイプ。authorization_code を指定します。
    client_id クライアントID
    redirect_uri コールバックURL。認可エンドポイントで使用された redirect_uri と同じ文字列を指定します。
    code 認可コード

    リクエストイメージ

    POST https://api.invox.jp/oauth2/token >
    Content-Type='application/x-www-form-urlencoded'&
    Authorization=Basic ENCODED_CLIENT_ID_AND_SECRET
    
    grant_type=authorization_code&
    client_id=CLIENT_ID&
    code=AUTHORIZATION_CODE&
    redirect_uri=https://YOUR_APP/REDIRECT_URI
    

    レスポンス内容

    HTTP/1.1 200 OK
    Content-Type: application/json
    
    {
        "access_token": "ACCESS_TOKEN",
        "expires_in": 36000,
        "token_type": "Bearer",
        "scope": "read write",
        "refresh_token": "REFRESH_TOKEN
    }
    

    ※アクセストークンの有効期限はexpires_inで返却された値(秒)です。  リフレッシュトークン(更新トークン)の有効期限はありません。

  • トークンのリフレッシュ
    https://api.invox.jp/oauth2/token/
    リクエストメソッド: POST
    トークンのリフレッシュ(有効なアクセストークンの再取得)に使用します。

    ヘッダー

    • Authorization
      Basic Base64Encode(CLIENT_ID:CLIENT_SECRET)
      クライアントIDとクライアントシークレットをコロン(:)でつないだ文字列をBase64でエンコードした値を、ベーシックHTTP認証を介して認証ヘッダー(Authorization)に渡します。

    • Content-Type
      application/x-www-form-urlencoded

    パラメータ

    名前 内容
    grant_type 付与タイプ。refresh_token を指定します。
    client_id クライアントID
    refresh_token 更新トークン

    リクエストイメージ

    POST https://api.invox.jp/oauth2/token >
    Content-Type='application/x-www-form-urlencoded'
    Authorization=Basic ENCODED_CLIENT_ID_AND_SECRET
    
    grant_type=refresh_token&
    client_id=CLIENT_ID&
    refresh_token=REFRESH_TOKEN
    

    レスポンス内容

    HTTP/1.1 200 OK
    Content-Type: application/json
    
    {
        "access_token": "ACCESS_TOKEN",
        "expires_in": 36000,
        "token_type": "Bearer",
        "scope": "read write",
        "refresh_token": "REFRESH_TOKEN"
    }
    

    ※リフレッシュされたアクセストークンの有効期限はexpires_inで返却された値(秒)です。  リフレッシュトークン(更新トークン)の有効期限はありません。

  • トークンの取り消し
    https://api.invox.jp/oauth2/revoke_token/
    リクエストメソッド: POST
    不要となったアクセストークンの取り消しに使用します。

    ヘッダー

    • Content-Type
      application/x-www-form-urlencoded

    パラメータ

    名前 内容
    token アクセストークン
    client_id クライアントID
    client_secret クライアントシークレット

    リクエストイメージ

    POST https://api.invox.jp/oauth2/revoke_token >
    Content-Type='application/x-www-form-urlencoded'
    
    token=ACCESS_TOKEN
    client_id=CLIENT_ID
    client_secret=CLIENT_SECRET
    

    レスポンス内容

    HTTP/1.1 200 OK
    

リクエスト共通仕様

ヘッダー

トークン

Bearerスキームでトークン認証を行います。

データフォーマット

Content-Type='application/json'

接続手順例

API接続の事前準備(invox電子帳簿保存の場合)

1. invox電子帳簿保存のご契約内容を確認します

プロフェッショナルプランによるご契約が必要です。

設定 > サービス > サービス・プラン設定 よりご確認ください。

2. 接続用ユーザーの用意します

invox電子帳簿保存にログイン可能なユーザーを登録してください。該当ユーザーによりアップロードされた書類として扱われます(接続用ユーザーを削除するとAPI接続ができなくなります)。

設定 > スタッフ より設定・確認可能です。

3. 企業IDを確認します

API接続時に「企業ID」が必要となります。

設定 > 会社 より確認可能です(システムが自動採番します。任意の値に変更はできません)。

APIを使った認証から登録(invox電子帳簿保存の場合)

1. 認可コード取得(初回のみ必要)

1-1. アクセス用URL(赤字部分含め弊社より提供)にアクセスします
https://api.invox.jp/oauth2/authorize/?response_type={response_type}&client_id={クライアントID}&redirect_uri={リダイレクトURI}&scope={scope}&state={state}
1-2. 事前準備で確認した接続用ユーザーでログオンします
1-3. アクセス許可を行います(invox電子帳簿保存の「書類の登録」が表示されていることを確認してください)
1-4. 認可コードを取得します

リダイレクト先に遷移した後、アドレスバーに表示された内容を保存してください(code=以降の文字列が認可コードです)。

認可コードは1分程度で失効しますので、すぐに「2.トークンの取得」を実施してください。

失効した場合は、再度1-1. からやり直して認可コードを取得してください。

2. トークンの取得

2-a. アクセストークンの取得例

curlコマンドの実行サンプル

curl -X POST -H "Authorization: Basic {クライアントIDとクライアントシークレットをコロン(:)でつないだ文字列をBase64でエンコードした値}"
  -H "Content-Type: application/x-www-form-urlencoded" "https://api.invox.jp/oauth2/token/"
  -d "grant_type=authorization_code"
  -d "client_id={クライアントID}"
  -d "redirect_uri={リダイレクトURI}"
  -d "code={1.で取得した認可コード}"

実行例

応答例(「アクセストークン」と「リフレッシュトークン」が返されます)

2-b. トークンのリフレッシュ例(トークンの期限切れ時に行ってください)

curlコマンドの実行サンプル

curl -X POST -H "Authorization: Basic {クライアントIDとクライアントシークレットをコロン(:)でつないだ文字列をBase64でエンコードした値}"
  -H "Content-Type: application/x-www-form-urlencoded" "https://api.invox.jp/oauth2/token/"
  -d "grant_type=refresh_token"
  -d "client_id={クライアントID}"
  -d "refresh_token={リフレッシュトークン}"
  1. と同様に「アクセストークン」と「リフレッシュトークン」が返されます

3. APIによる電子帳簿保存の書類登録

  1. で取得した「トークン」と事前準備で確認した「企業ID」が必要となります。

以下、python3 による簡易スクリプト例です。別途「sample.pdf」ファイルを用意します。

import base64
import json
import requests

def main():
  headers = {
    "Authorization": "Bearer {アクセストークン}",
    "content-type": "application/json",
  }
  url = "https://api.invox.jp/api/public/e_storage"

  file_content = open("sample.pdf", "rb").read()
  data = {
    "invox_company_code": "{企業ID}",
    "e_storage": {
      "doc_type": "見積書(受領)",
      "entry_method": "user",
      "file_name": "sample.pdf",
      "file_content": base64.b64encode(file_content).decode("utf-8"),
      "partner_name": "partner_name",
      "transaction_date": "2023/07/01",
      "transaction_amount": "123456",
      "currency_code": "JPY",
      "staff_name": "staff",
    }
  }
  res = requests.post(url, headers=headers, data=json.dumps(data))

if __name__ == "__main__":
  main()

レスポンス例:書類IDと書類URLが返却されます

HTTP/1.1 200 OK
Content-Type: application/json

{
  "id": "DOCUMENT_ID",
  "url": "DOCUMENT_URL",
}

4. 登録の確認

invox電子帳簿保存にログオンして書類が登録されていることを確認してください。

検索条件の「取込経路」が「API」で検索される書類がAPIによって登録されたものになります。

FAQ

  • Q. invox APIのOAth2.0の利用方法について教えてください

    • A. 以下手順となります。(事前にクライアントIDとクライアントシークレットを取得してください)
      1. クライアントIDを使用して、認可コードを取得
      2. 認可コード、クライアントID、シークレットを使用して、アクセストークンを取得
      3. アクセストークンを使ってAPIを利用
      4. アクセストークンの利用期限が切れた場合は、リフレッシュトークン、クライアントID、シークレットを使用してトークンのリフレッシュを行い、アクセストークンを更新
      • 以後3.および4.を繰り返しご利用ください(1.,2.の手順は初回のみ)
  • Q. コールバックURI(redirect_uri)はどのように指定すればよいですか?

    • A. ご希望されるURIがある場合は、API利用時にお申し出ください。特にない場合は、invoxのログイン画面を設定いたします。
  • Q. トークンの有効期限はどのくらいですか?

    • A. アクセストークンの有効期限は36000秒(10時間)です。リフレッシュトークン(更新トークン)の有効期限はありません。
  • Q. トークンの有効期限が切れた場合はどうすればよいですか?

    • A. トークンのリフレッシュにより有効なアクセストークン(有効期限10時間)を取得することができます。
  • Q. invox電子帳簿保存 書類登録を利用するにはどのようなプランが必要ですか?

    • A. プロフェッショナルプランのご契約が必要です。
  • Q. invox電子帳簿保存 書類登録で複数の書類を1度に登録することはできますか?

    • A. できません。1度に1書類の登録となります。
  • Q. invox電子帳簿保存 書類登録で登録可能なファイルの種類に制限はありますか?

    • A. ファイルの種類に制限はありません。ただし、画像ファイル(jpg、png、gif、bmp、tiff)とPDF以外はinvox電子帳簿保存上で画像イメージを表示することはできません。
  • Q. invox電子帳簿保存 書類登録で登録可能なファイルサイズの制限はありますか?

    • A. ファイル含め、リクエストの最大サイズを50メガバイトに制限しております。
  • Q. invox電子帳簿保存に登録済みの書類データを取得するAPIはありますか?

    • A. ありません。書類データの確認はinvox電子帳簿保存上で行ってください。

invox受取請求書

invox受取請求書の機能を提供します。
利用例(受取請求書)

請求書登録

Authorizations:
OAuth2
Request Body schema: multipart/form-data
  • 請求書ファイルが請求書として認識されなかった場合、以下の項目の入力値は反映されません。 請求日、支払期限、仕入先コード、登録番号、通貨コード、請求金額、課税10%(税込) 、課税10%(消費税) 、課税8%(税込) 、課税8%(消費税)、非課税、不課税、源泉徴収
  • マスタに該当するデータがない場合、以下の項目は反映されません。 部門コード、プロジェクトコード、担当者のスタッフコード、工種コード
  • 金額入力時は請求金額と内訳金額を合わせる必要があります。計算式は以下の通り 課税10%(税込) + 課税8%(税込) + 非課税 + 不課税 - 源泉徴収 = 請求金額
invox_company_code
required
string <= 30 characters

企業ID

file
required
binary <= 50MB

請求書ファイル(ファイル形式:pdf,jpeg,png)

required
object
entry_method
required
string

データ化方法

  • ocr - AI OCR
  • operator - オペレーター入力
  • auto - 自動判定
invoice_date
string

請求日(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

payment_due_date
string

支払期限(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

supplier_code
string <= 250 characters

仕入先コード データ化方法がocrの場合のみ反映されます

corporate_tax_no
string <= 14 characters

登録番号

department_code
string <= 30 characters

部門コード

project_code
string <= 30 characters

プロジェクトコード

staff_code
string <= 30 characters

担当者のスタッフコード

extension_param1
string <= 250 characters

拡張項目1

extension_param2
string <= 250 characters

拡張項目2

extension_param3
string <= 250 characters

拡張項目3

extension_param4
string <= 250 characters

拡張項目4

extension_param5
string <= 250 characters

拡張項目5

construction_type
string <= 30 characters

工種コード

voucher_no
string <= 30 characters

伝票No

currency_code
string <= 3 characters

通貨コード

amt_invoice
number <= 999999999999.999

請求金額

amt_taxin10
number <= 999999999999.999

課税10%(税込) 入力時は課税10%(消費税)の入力が必須となります。

amt_tax10
number <= 999999999999.999

課税10%(消費税) 入力時は課税10%(税込)の入力が必須となります。

amt_taxin8
number <= 999999999999.999

課税8%(税込) 入力時は課税8%(消費税)の入力が必須となります。

amt_tax8
number <= 999999999999.999

課税8%(消費税) 入力時は課税8%(税込)の入力が必須となります。

amt_non_taxable
number <= 999999999999.999

非課税

amt_un_taxable
number <= 999999999999.999

不課税

amt_withholding_tax
number <= 999999999999.999

源泉徴収

memo
string

メモ

Responses

Response samples

Content type
application/json
{
  • "invoice_id": "string"
}

請求書一覧取得

Authorizations:
OAuth2
query Parameters
invox_company_code
required
string <= 30 characters

企業ID

invoice_date_from
string <date>

請求日From(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

invoice_date_to
string <date>

請求日To(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

payment_plan_date_from
string <date>

支払予定日From(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

payment_plan_date_to
string <date>

支払予定日To(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

posting_date_from
string <date>

計上日From(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

posting_date_to
string <date>

計上日To(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

fixed_only
bool

確定のみ検索フラグ(未指定の場合はtrueとなります) trueの場合、確定済み以降のステータスのもののみ検索結果に含める

export_status
string
Enum: "invoice_unexported" "payment_unexported" "expense_journal_unexported"

出力状況

  • invoice_unexported - 請求データ未出力
  • payment_unexported - 振込データ未出力
  • expense_journal_unexported - 費用計上仕訳未出力
payment_method
string (PaymentMethodEnum)
Enum: "bank_transfer" "direct_debit" "credit_card" "cash" "check" "promissory_note" "densai" "international_transfer" "other"

支払方法

  • bank_transfer - 銀行振込
  • direct_debit - 口座振替
  • credit_card - クレジットカード
  • cash - 現金
  • check - 小切手
  • promissory_note - 手形
  • densai - でんさい
  • international_transfer - 海外送金
  • other - その他
department_code
string <= 30 characters

部門コード

include_sub_departments
bool

下位部門フラグ trueの場合、部門コードに指定した部門の下位部門も検索結果に含める

page
number

ページ数

Responses

Response samples

Content type
application/json
{
  • "count": 0,
  • "next": "string",
  • "previous": "string",
  • "results": [
    ]
}

請求書取得

Authorizations:
OAuth2
query Parameters
invox_company_code
required
string <= 30 characters

企業ID

invoice_id
required
string <= 45 characters

請求書ID

include_journal_info
bool

trueの場合、responseに仕訳情報を含める

Responses

Response samples

Content type
application/json
{
  • "invoice_id": "string",
  • "supplier_code": "string",
  • "corporate_tax_no": "string",
  • "department_code": "string",
  • "project_code": "string",
  • "staff_code": "string",
  • "extension_param1": "string",
  • "extension_param2": "string",
  • "extension_param3": "string",
  • "extension_param4": "string",
  • "extension_param5": "string",
  • "construction_type": "string",
  • "voucher_no": "string",
  • "invoice_date": "2024/01/01",
  • "payment_due_date": "2024/01/01",
  • "payment_plan_date": "2024/01/01",
  • "currency_code": "str",
  • "amt_invoice": 999999999999.999,
  • "amt_taxin10": 999999999999.999,
  • "amt_tax10": 999999999999.999,
  • "amt_taxin8": 999999999999.999,
  • "amt_tax8": 999999999999.999,
  • "amt_non_taxable": 999999999999.999,
  • "amt_un_taxable": 999999999999.999,
  • "amt_withholding_tax": 999999999999.999,
  • "memo": "string",
  • "title": "string",
  • "invoice_no": "string",
  • "post_code": "string",
  • "address": "string",
  • "payment_info": {
    },
  • "appr_path_id": 0,
  • "journal_info": {
    }
}

請求書更新

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

invoice_id
required
string <= 45 characters

請求ID

add_memo
bool

メモ追記フラグ trueの場合、メモを追記する

recreate_journal
bool

再仕訳フラグ trueの場合、仕訳を再生成する。指定されていない場合はfalse

required
object
department_code
string <= 30 characters

部門コード

project_code
string <= 30 characters

プロジェクトコード

staff_code
string <= 30 characters

担当者コード

extension_param1
string <= 250 characters

拡張項目1

extension_param2
string <= 250 characters

拡張項目2

extension_param3
string <= 250 characters

拡張項目3

extension_param4
string <= 250 characters

拡張項目4

extension_param5
string <= 250 characters

拡張項目5

construction_type
string <= 30 characters

工種コード

voucher_no
string <= 30 characters

伝票No

invoice_date
string <date>

請求日(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

payment_due_date
string <date>

支払期限(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

payment_plan_date
string <date>

支払予定日(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

currency_code
string <= 3 characters

通貨コード

amt_invoice
number <= 999999999999.999

請求金額

amt_taxin10
number <= 999999999999.999

課税10% 税込

amt_tax10
number <= 999999999999.999

課税10% 消費税

amt_taxin8
number <= 999999999999.999

課税8% 税込

amt_tax8
number <= 999999999999.999

課税8% 消費税

amt_non_taxable
number <= 999999999999.999

非課税

amt_un_taxable
number <= 999999999999.999

不課税

amt_withholding_tax
number <= 999999999999.999

源泉徴収

memo
string

メモ

title
string <= 250 characters

件名

invoice_no
string <= 45 characters

請求番号

exclude_export_invoice
boolean or null

請求データ出力対象外

exclude_export_payment
boolean or null

支払データ出力対象外

exclude_export_expense_journal
boolean or null

費用計上仕訳データ出力対象外

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "invoice_id": "string",
  • "add_memo": null,
  • "recreate_journal": null,
  • "invoice": {
    }
}

Response samples

Content type
application/json
{ }

添付ファイル登録

Authorizations:
OAuth2
Request Body schema: multipart/form-data
invox_company_code
required
string <= 30 characters

企業ID

invoice_id
required
string <= 45 characters

請求書ID

file
required
binary <= 10MB

添付ファイル

Responses

Response samples

Content type
application/json
{ }

仕訳計上日更新

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

invoice_id
required
string <= 45 characters

請求ID

journal_type
required
string

仕訳種別

  • expense - 費用計上仕訳
object
posting_date
string <date>

計上日(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "invoice_id": "string",
  • "journal_type": "string",
  • "journal": {
    }
}

Response samples

Content type
application/json
{ }

ワークフロー申請

API経由でワークフローの申請を行う場合、以下の制限があります。

  • 承認パスの全てのステップがスキップされる場合、申請はできません。
Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

invoice_id
required
string <= 45 characters

請求書ID

appr_path_id
number

承認パスID

staff_code
required
string <= 30 characters

申請スタッフコード

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "invoice_id": "string",
  • "appr_path_id": 0,
  • "staff_code": "string"
}

Response samples

Content type
application/json
{ }

ワークフロー承認

APIの接続用ユーザに設定の編集権限があるかどうかで承認されるステップが異なります。

  • 設定編集権限がある場合:承認者に関わらず、APIの接続用ユーザを承認者として承認を行います。
  • 設定編集権限がない場合:APIの接続用ユーザが承認者となっているステップの承認を行います。

また、以下の制限があります。

  • 確定時に外部サービスと連携する設定にしている場合でも、確定時に連携はされません。
Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

invoice_id
required
string <= 45 characters

請求書ID

approve_task_name
required
string <= 250 characters

承認タスク名

appr_path_id
number

承認パスID

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "invoice_id": "string",
  • "approve_task_name": "string",
  • "appr_path_id": 0
}

Response samples

Content type
application/json
{ }

請求書出力済み設定

請求書の出力状況を出力済みに変更します。 請求書のステータスが「出力待ち」の時のみ変更です。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

invoice_id
required
string <= 45 characters

請求書ID

export_data_type
required
string
Enum: "invoice" "payment" "expense_journal"

出力データタイプ

  • invoice - 請求データ
  • payment - 支払データ
  • expense_journal 費用計上仕訳

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "invoice_id": "string",
  • "export_data_type": "invoice"
}

Response samples

Content type
application/json
{ }

仕入先追加・更新

同一の仕入先コードのデータがある場合は更新、ない場合は追加します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

required
object
code
required
string <= 250 characters

仕入先コード

name
required
string <= 250 characters

仕入先名

exclude_on_digitization
boolean

データ化時はこの仕入先は利用しない

company_type
string
Enum: "corporate" "individual"

法人/個人

  • corporate - 法人
  • individual - 個人
is_withholding_tax
boolean

源泉徴収対象

taxable_type
string
Enum: "taxable" "exempt"

源泉種別

  • taxable - 課税事業者
  • exempt - 免税事業者
corporate_tax_no
string <= 14 characters

登録番号

exclude_invoice_check
boolean

インボイスの要件チェックの対象外とする

extension_param1
string <= 250 characters

拡張項目1

extension_param2
string <= 250 characters

拡張項目2

extension_param3
string <= 250 characters

拡張項目3

extension_param4
string <= 250 characters

拡張項目4

extension_param5
string <= 250 characters

拡張項目5

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "supplier": {
    }
}

Response samples

Content type
application/json
{ }

仕入先削除

仕入先を削除します。
ただし、未確定の請求書に紐づく仕入先は削除できません。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

code
string <= 250 characters

仕入先コード

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "code": "string"
}

Response samples

Content type
application/json
{ }

仕入先支払設定追加・更新

同一の支払方法のデータがある場合は更新、ない場合は追加します。
支払設定上書きは、支払設定が0もしくは1つの時のみ成功します。 支払方法が異なる支払設定を上書きする場合、既存の支払設定は削除され、新しい支払設定が追加されます。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

required
object
supplier_code
required
string <= 250 characters

仕入先コード

payment_method
required
string
Enum: "bank_transfer" "direct_debit" "credit_card" "cash" "check" "promissory_note" "densai" "international_transfer" "other"

支払方法

  • bank_transfer - 銀行振込
  • direct_debit - 口座振替
  • credit_card - クレジットカード
  • cash - 現金
  • check - 小切手
  • promissory_note - 手形
  • densai - でんさい
  • international_transfer - 海外送金
  • other - その他
object

銀行振込の時は必須

is_overwrite
boolean

支払設定上書き

link_trade_setting
boolean

取引設定に紐付ける

trade_setting_department_code
string <= 30 characters

取引設定の部門コード

trade_setting_project_code
string <= 30 characters

取引設定のプロジェクトコード

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "supplier_payment_method": {
    }
}

Response samples

Content type
application/json
{ }

スタッフ追加・更新

同一のメールアドレスのデータがある場合は更新、ない場合は追加します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
string <= 30 characters

企業ID

object
mail_address
required
string <= 250 characters

メールアドレス

name
required
string <= 50 characters

名前

code
required
string <= 30 characters

コード

Array of objects

部門、役職情報の配列 2つめ以降は兼任設定となる

object

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "staff": {
    }
}

Response samples

Content type
application/json
{ }

スタッフ削除

スタッフを削除します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

mail_address
required
string <= 250 characters

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "mail_address": "string"
}

Response samples

Content type
application/json
{ }

部門追加・更新

同一の部門コードのデータがある場合は更新、ない場合は追加します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

required
Array of objects
Array
parent_code
string <= 30 characters

親部門コード

code
required
string <= 30 characters

部門コード

name
required
string <= 250 characters

部門名

is_indirect
boolean

間接部門

invoice_staff_code
string <= 30 characters

請求担当者コード

memo
string

メモ

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "departments": [
    ]
}

Response samples

Content type
application/json
{ }

部門削除

部門を削除します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

code
required
string <= 30 characters

部門コード

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "code": "string"
}

Response samples

Content type
application/json
{ }

プロジェクト追加・更新

同一コードのプロジェクトがある場合は更新、ない場合は追加します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

required
object
code
required
string <= 30 characters

プロジェクトコード

name
required
string <= 250 characters

プロジェクト名

is_indirect
boolean

間接プロジェクト

department_code
string <= 30 characters

部門コード

primary_staff_code
string <= 30 characters

主担当者コード

secondary_staff_code
string <= 30 characters

副担当者コード

amt_order
number <= 999999999999.999

受注金額

start_date
string <date>

開始日(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

end_date
string <date>

終了日(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

memo
string

メモ

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "project": {
    }
}

Response samples

Content type
application/json
{ }

プロジェクト削除

プロジェクトを削除します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

code
required
string <= 30 characters

プロジェクトコード

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "code": "string"
}

Response samples

Content type
application/json
{ }

汎用マスタ追加・更新

同一コードのデータがある場合は更新、ない場合は追加します。 汎用マスタグループは事前に作成しておく必要があります。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

grp_code
required
string <= 30 characters

汎用マスタグループコード

required
Array of objects

汎用マスタの配列

Array
code
required
string <= 30 characters
name
required
string <= 250 characters
memo
string
delete_not_in_masters
bool

含まれないマスタの削除フラグ trueの場合、mastersに含まれていなかったデータを削除する

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "grp_code": "string",
  • "masters": [
    ],
  • "delete_not_in_masters": null
}

Response samples

Content type
application/json
{ }

汎用マスタ削除

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

grp_code
required
string <= 30 characters

汎用マスタグループコード

code
required
string <= 30 characters

汎用マスタコード

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "grp_code": "string",
  • "code": "string"
}

Response samples

Content type
application/json
{ }

勘定科目追加・更新

同一コードの勘定科目がある場合は更新、ない場合は追加します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
string <= 30 characters

企業ID

object
code
required
string <= 30 characters

コード

name
required
string <= 250 characters

名称

type
string

勘定科目種別

  • credit - 債権科目
  • debit - 債務科目
tax_type_code
required
string <= 30 characters

税区分コード

search_key
string <= 250 characters

検索キー

order
number

表示順

use_sub_account
string

仕訳明細の入力制御(補助科目)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_department
string

仕訳明細の入力制御(部門)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_project
string

仕訳明細の入力制御(プロジェクト)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_supplier
string

仕訳明細の入力制御(仕入先)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_extension_selection1
string

仕訳明細の入力制御(拡張選択項目1)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_extension_selection2
string

仕訳明細の入力制御(拡張選択項目2)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_extension_selection3
string

仕訳明細の入力制御(拡張選択項目3)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_extension_selection4
string

仕訳明細の入力制御(拡張選択項目4)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_extension_selection5
string

仕訳明細の入力制御(拡張選択項目5)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_extension_selection6
string

仕訳明細の入力制御(拡張選択項目6)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_extension_selection7
string

仕訳明細の入力制御(拡張選択項目7)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_extension_selection8
string

仕訳明細の入力制御(拡張選択項目8)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない
use_extension_selection9
string

仕訳明細の入力制御(拡張選択項目9)

  • required - 必須
  • optional - 任意
  • not_used - 使用しない

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "account": {
    }
}

Response samples

Content type
application/json
{ }

勘定科目削除

勘定科目を削除します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

code
required
string <= 30 characters

コード

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "code": "string"
}

Response samples

Content type
application/json
{ }

補助勘定科目追加・更新

同一コードの補助勘定科目がある場合は更新、ない場合は追加します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

account_code
required
string <= 30 characters

親勘定科目コード

required
object
code
required
string <= 30 characters

コード

name
required
string <= 250 characters

名称

tax_type_code
string <= 30 characters

税区分コード

search_key
string <= 250 characters

検索キー

order
number

表示順

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "account_code": "string",
  • "sub_account": {
    }
}

Response samples

Content type
application/json
{ }

補助勘定科目削除

補助勘定科目を削除します。

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

account_code
required
string <= 30 characters

親勘定科目コード

code
required
string <= 30 characters

補助科目コード

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "account_code": "string",
  • "code": "string"
}

Response samples

Content type
application/json
{ }

invox発行請求書

invox発行請求書の機能を提供します。

請求書登録

Authorizations:
OAuth2
Request Body schema: application/json
invox_company_code
required
string <= 30 characters

企業ID

skip_user_confirm_when_no_warnings_or_errors
boolean or null
Default: false

自動確定可否

required
object

請求情報

ユーザー定義項目は請求項目設定に従い入力してください

invoice_date
string or null

請求日

  • フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります
  • 未入力時は「請求日設定」に従います
invoice_no
string or null <= 45 characters

請求番号

未入力時は「請求番号 自動採番設定」に従います

title
string or null <= 250 characters

件名

client_code
required
string <= 250 characters

得意先コード

department_code
string or null <= 30 characters

部門コード

project_code
string or null <= 30 characters

プロジェクトコード

staff_code
string or null <= 30 characters

担当者コード

payment_due_date
string or null

支払期限

  • フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります
  • 未入力時は「支払期限設定」に従います
note
string or null

備考

memo
string or null

メモ

tags
Array of strings or null <= 250 characters

タグ

入力例:["tag1", "tag2"]

amt_entry_mode
string or null
Enum: "taxin" "taxout"

金額の入力方法

未入力時は「事業者・金額計算設定」に従います

  • taxin - 税込
  • taxout - 税抜
exclude_clearing
boolean or null
Default: false

入金消込対象外フラグ

  • true - 入金消込対象外
  • false - 入金消込対象
amt_previous_invoice
number or null <= 999999999999.999

前回請求残高

請求項目設定において「前回請求残高」をONにした場合にのみ使用可能です

amt_deposit
number or null <= 999999999999.999

今回入金額

請求項目設定において「今回入金額」をONにした場合にのみ使用可能です

currency_code
string or null <= 3 characters
Default: "JPY"

通貨コード

ISO 4217に準拠します

exclude_journal_export
boolean or null
Default: false

仕訳出力対象外フラグ

  • true - 仕訳出力対象外
  • false - 仕訳出力対象
custom_field_value1
string or null <= 250 characters

ユーザ定義項目1

custom_field_value2
string or null <= 250 characters

ユーザ定義項目2

custom_field_value3
string or null <= 250 characters

ユーザ定義項目3

custom_field_value4
string or null <= 250 characters

ユーザ定義項目4

custom_field_value5
string or null <= 250 characters

ユーザ定義項目5

custom_field_value6
string or null <= 250 characters

ユーザ定義項目6

custom_field_value7
string or null <= 250 characters

ユーザ定義項目7

custom_field_value8
string or null <= 250 characters

ユーザ定義項目8

custom_field_value9
string or null <= 250 characters

ユーザ定義項目9

custom_field_value10
string or null <= 250 characters

ユーザ定義項目10

custom_field_value11
string or null <= 250 characters

ユーザ定義項目11

custom_field_value12
string or null <= 250 characters

ユーザ定義項目12

custom_field_value13
string or null <= 250 characters

ユーザ定義項目13

custom_field_value14
string or null <= 250 characters

ユーザ定義項目14

custom_field_value15
string or null <= 250 characters

ユーザ定義項目15

custom_field_value16
string or null <= 250 characters

ユーザ定義項目16

custom_field_value17
string or null <= 250 characters

ユーザ定義項目17

custom_field_value18
string or null <= 250 characters

ユーザ定義項目18

custom_field_value19
string or null <= 250 characters

ユーザ定義項目19

custom_field_value20
string or null <= 250 characters

ユーザ定義項目20

object or null

送付情報

未入力時は「得意先取引設定」に従います

sending_method
string or null
Enum: "email" "email_download_link" "post" "post_by_user" "fax" "postal_service"

送付方法

  • email - メール(添付ファイル)
  • email_download_link - メール(ダウンロードリンク)
  • post - 郵送(Webレター)
  • post_by_user - 郵送(セルフ)
  • fax - FAX
  • postal_service - 郵送(代行)
send_address1
string or null <= 250 characters

宛先1行目(印字)

send_address2
string or null <= 250 characters

宛先2行目(印字)

send_address3
string or null <= 250 characters

宛先3行目(印字)

send_address4
string or null <= 250 characters

宛先4行目(印字)

send_address5
string or null <= 250 characters

宛先5行目(印字)

email_to_address
string or null <= 250 characters

メール(To)

email_cc_address
string or null

メール(Cc)

複数指定する場合はカンマで区切って入力してください(入力例:"cc_1@example.com,cc_2@example.com")

email_bcc_address
string or null

メール(Bcc)

複数指定する場合はカンマで区切って入力してください(入力例:"bcc_1@example.com,bcc_2@example.com")

email_reply_to
string or null <= 250 characters

返信先メールアドレス

receiver_post_code
string or null <= 8 characters

郵送(郵便番号)

receiver_state
string or null <= 16 characters

郵送(都道府県名)

receiver_city
string or null <= 16 characters

郵送(市区町村名)

receiver_address_line1
string or null <= 32 characters

郵送(町域名)

receiver_address_line2
string or null <= 32 characters

郵送(丁目・番地等)

receiver_address_line3
string or null <= 32 characters

郵送(建物名・部屋番号)

receiver_company_name
string or null <= 32 characters

郵送(会社名)

receiver_department_name
string or null <= 32 characters

郵送(部署名)

receiver_position
string or null <= 32 characters

郵送(肩書・役職)

receiver_person_in_charge
string or null <= 32 characters

郵送(担当者名)

receiver_honorific_title
string or null <= 5 characters

郵送(敬称)

exclude_sending
boolean or null
Default: false

送付対象外フラグ

  • true - 送付対象外
  • false - 送付対象
fax_number
string or null <= 16 characters

FAX番号

required
Array of objects

請求明細

請求明細項目設定に基づいて入力してください

Array
item_no
string or null <= 250 characters

品番

item_name
string or null <= 250 characters

品名

quantity
number or null decimal places <= 5 < 1000000000000

数量

quantity_unit
string or null <= 32 characters

単位

unit_price
number or null decimal places <= 5 < 1000000000000

単価

tax_kind
string or null
Enum: "standard10" "reduced8" "non_taxable" "un_taxable"

消費税区分

  • standard10 - 10%
  • reduced8 - 軽減8%
  • non_taxable - 非課税
  • un_taxable - 不課税
withholding_tax_required
boolean or null
Default: false

源泉対象フラグ

事業者・金額計算設定において「源泉徴収税を利用する」をONにした場合にのみ使用可能です

  • true - 源泉徴収対象
  • false - 源泉徴収対象外
amt_tax
number or null <= 999999999999.999

消費税額

事業者・金額計算設定において「請求明細ごとの消費税額の入力を利用する」をONにした場合にのみ使用可能です

group_start_mark
boolean or null
Default: false

明細グループ開始フラグ

請求作成・送付設定において「請求明細の設定」の明細グループ化をONにした場合にのみ使用可能です trueにすることで明細グループの開始行に設定されます

amt_withholding_tax
number or null <= 999999999999.999

源泉徴収税額

事業者・金額計算設定において「請求明細ごとの源泉徴収税額の入力を利用する」をONにした場合にのみ使用可能です

custom_field_value1
string or null <= 250 characters

ユーザ定義項目1

custom_field_value2
string or null <= 250 characters

ユーザ定義項目2

custom_field_value3
string or null <= 250 characters

ユーザ定義項目3

custom_field_value4
string or null <= 250 characters

ユーザ定義項目4

custom_field_value5
string or null <= 250 characters

ユーザ定義項目5

custom_field_value6
string or null <= 250 characters

ユーザ定義項目6

custom_field_value7
string or null <= 250 characters

ユーザ定義項目7

custom_field_value8
string or null <= 250 characters

ユーザ定義項目8

custom_field_value9
string or null <= 250 characters

ユーザ定義項目9

custom_field_value10
string or null <= 250 characters

ユーザ定義項目10

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "skip_user_confirm_when_no_warnings_or_errors": false,
  • "issue_invoice": {
    },
  • "issue_invoice_sending": {
    },
  • "issue_invoice_details": [
    ]
}

Response samples

Content type
application/json
{
  • "issue_invoice_id": "string",
  • "url": "string"
}

添付ファイル登録

Authorizations:
OAuth2
Request Body schema: multipart/form-data
invox_company_code
required
string <= 30 characters

企業ID

issue_invoice_id
required
string <= 45 characters

請求書ID

file
required
binary

添付ファイル

attach_when_sending
boolean or null
Default: false

請求書送付時添付フラグ

  • true - 請求書送付時に添付されます
  • false - 請求書送付時に添付されません
  • 請求書の送付方法がメールではない場合、falseとなります

Responses

Response samples

Content type
application/json
{ }

invox電子帳簿保存

invox電子帳簿保存の書類登録機能を提供します。

書類登録

Authorizations:
OAuth2
Request Body schema: application/json

以下の場合には、指定された値は無視されて、登録処理が継続されます。

  • 必須項目以外は、不適切な値の場合(型の不一致、フォーマットが不適切など)

  • マスタ参照を行う項目(対象は以下項目)は、一意にデータを特定できない場合

    対象項目:取引コード、取引名、通貨コード、部門コード、部門名、プロジェクトコード、プロジェクト名、担当者コード、担当者名、タグ名、拡張項目(汎用マスタの場合)

invox_company_code
required
string <= 30 characters

企業ID

object
doc_type
required
string <= 250 characters

書類名

entry_method
required
string (EntryMethodEnum)
Enum: "user" "ocr" "operator"
  • user - セルフ入力
  • ocr - AI OCR
  • operator - オペレーター入力
file_name
required
string <= 250 characters

ファイル名(拡張子でファイルの種類を判定します。画像ファイル以外はinvox電子帳簿保存上で「NO IMAGE」書類となります。)

file_content
required
string

ファイル内容(base64エンコード)

transaction_code
string or null <= 30 characters

取引コード

transaction_name
string or null <= 250 characters

取引名(「取引コード」が指定されている場合には、「取引コード」が優先されます)

partner_name
string or null <= 250 characters

取引先名(250文字より長い部分は切り捨てます)

corporate_tax_no
string or null <= 14 characters

登録番号(適格請求書発行事業者の登録番号です。「取引先名」が未指定の場合に、この登録番号から取得した名称が取引先名として設定されます)

transaction_amount
string or null <= 999999999999.999

取引金額(小数点以下が3桁、全部で15桁が制限となります)

currency_code
string or null <= 3 characters
Default: "JPY"

通貨コード(日本円:JPY、米ドル:USD... 未指定の場合は日本円になります)

transaction_date
string or null <= 10 characters

取引日(フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります)

department_code
string or null <= 30 characters

部門コード

department_name
string or null <= 250 characters

部門名(「部門コード」が指定されている場合には、「部門コード」が優先されます)

project_code
string or null <= 30 characters

プロジェクトコード

project_name
string or null <= 250 characters

プロジェクト名(「プロジェクトコード」が指定されている場合には、「プロジェクトコード」が優先されます)

staff_code
string or null <= 30 characters

担当者コード

staff_name
string or null <= 50 characters

担当者名(「担当者コード」が指定されている場合には、「担当者コード」が優先されます)

tag
string or null <= 250 characters

タグ(単一指定)

tags
Array of strings or null

タグ名(複数指定) 単一指定、複数指定が同時に指定されても共に登録されます

voucher_number
string or null <= 30 characters

伝票番号(30文字より長い部分は切り捨てます)

extension_param1
string or null <= 250 characters

拡張項目1

拡張項目はinvox電子帳簿保存側で設定された「入力形式」によって挙動が変わります

  • 日付:フォーマットは「YYYY-MM-DD」「YYYY/MM/DD」「YYYYMMDD」のいずれかとなります
  • 選択(汎用マスタ):対応する汎用マスタの名称と完全一致
  • 上記以外は、そのまま登録されます(250文字より長い部分は切り捨てます)
extension_param2
string or null <= 250 characters

拡張項目2

extension_param3
string or null <= 250 characters

拡張項目3

extension_param4
string or null <= 250 characters

拡張項目4

extension_param5
string or null <= 250 characters

拡張項目5

extension_param6
string or null <= 250 characters

拡張項目6

extension_param7
string or null <= 250 characters

拡張項目7

extension_param8
string or null <= 250 characters

拡張項目8

extension_param9
string or null <= 250 characters

拡張項目9

extension_param10
string or null <= 250 characters

拡張項目10

Responses

Request samples

Content type
application/json
{
  • "invox_company_code": "string",
  • "e_storage": {
    }
}

Response samples

Content type
application/json
{
  • "id": "string",
  • "url": "string"
}

添付ファイル登録

Authorizations:
OAuth2
Request Body schema: multipart/form-data
invox_company_code
required
string <= 30 characters

企業ID

e_storage_id
required
string <= 45 characters

書類ID

file
required
binary <= 10MB

添付ファイル

Responses

Response samples

Content type
application/json
{ }

利用例(受取請求書)

仕訳データを取得して別システムへ連携する

1. 連携対象の請求IDの一覧を取得

請求書一覧取得APIで、export_statusにexpense_journal_unexported(費用計上仕訳未出力)を指定して、確定済みかつ仕訳データ未出力の請求データの一覧を取得します。

2. 対象の請求書の仕訳データを取得

請求書取得APIで、1.で取得した請求IDと、include_journal_infoにtrueを指定して、請求データと仕訳データを取得します。

3. 仕訳データを連携する

2.で取得した仕訳データを別システムへ連携します。

4. 出力済みに設定

請求書出力済み設定APIに請求IDと、export_data_typeにexpense_journalを指定して、出力済みとします。

import base64
import json
import requests

def main():
  headers = {
    "Authorization": "Bearer {アクセストークン}",
    "content-type": "application/json",
  }
  # 1. 連携対象の請求IDの一覧を取得
  # (ページングの考慮はしていません。)
  list_url = "https://api.invox.jp/api/public/invoice_receive/invoice/list"
  list_params = {
    "invox_company_code": "{企業ID}",
    "export_status": "expense_journal_unexported",
  }
  list_result = requests.get(list_url, params=list_params, headers=headers)

  for item in list_result.json()["results"]:
    # 2. 対象の請求書の仕訳データを取得
    get_url = "https://api.invox.jp/api/public/invoice_receive/invoice/get"
    get_params = {
      "invox_company_code": "{企業ID}",
      "invoice_id": item["invoice_id"],
      "include_journal_info": True,
    }
    get_result = requests.get(get_url, params=get_params, headers=headers)

    # 3. 仕訳データを連携する
    # (ここでは例として、標準出力しています。)
    print(get_result.json().get("journal_info"))

    # 4. 出力済みに設定
    set_exported_url = "https://api.invox.jp/api/public/invoice_receive/invoice/set_exported"
    set_exported_params = {
      "invox_company_code": "{企業ID}",
      "invoice_id": item["invoice_id"],
      "export_data_type": "expense_journal",
    }
    requests.post(set_exported_url, data=json.dumps(set_exported_params), headers=headers)

if __name__ == "__main__":
  main()