eLTAX地方税ダイレクト納付の口座振替設定を自動確認するシステム
はじめに
税理士事務所で関与先企業の地方税ダイレクト納付を管理している方向けの技術記事です。
解決する課題:
- 関与先ごとにeLTAXにログインして口座振替設定を確認する手作業
- 設定済み口座の詳細情報(金融機関名・支店・名義人)の取得
- 複数社分の確認作業の効率化
この記事で得られるもの:
- Python + Seleniumによる完全自動化システム
- Windows/Mac両対応の実装
- 数十社分の確認作業を無人実行
システム概要
処理フロー
- CSVファイルから納税者情報を読み込み
- 各納税者IDでeLTAXに自動ログイン
- 口座情報の確認・変更 → 納税メニューと画面遷移
- 口座振替設定の有無と詳細情報を取得
- 結果をExcelファイルに出力
動作環境
- Python 3.8+
- Google Chrome + ChromeDriver
- Windows 10/11 または macOS
セットアップ
1. 必要ライブラリのインストール
pip install selenium pandas openpyxl schedule
2. ChromeDriverのセットアップ
Windows
# Chocolateyを使用する場合
choco install chromedriver
# 手動の場合
# 1. https://chromedriver.chromium.org/ からダウンロード
# 2. PATHの通った場所に配置
Mac
# Homebrewを使用
brew install chromedriver
# セキュリティ許可
xattr -d com.apple.quarantine /opt/homebrew/bin/chromedriver
3. 納税者情報CSVファイルの準備
納税者一覧.csvを作成:
user_id,password,taxpayer_name
利用者ID1,パスワード1,株式会社サンプル
利用者ID2,パスワード2,合同会社テスト
実装コード
完全なソースコードはGitHub Gistで公開しています:
🔗 GitHub Gist - eLTAX口座振替確認自動化システム
主要機能
- Windows/Mac環境自動判定
- 複数セレクターパターンでの要素検出
- 詳細なログ出力とエラーハンドリング
- 進捗表示と実行時間推定
- Excel形式での結果出力
ファイル構成
project/
├── eltax_checker.py # メインスクリプト(上記Gistからダウンロード)
└── 納税者一覧.csv # 納税者情報
CSVファイル形式
user_id,password,taxpayer_name
利用者ID1,パスワード1,株式会社サンプル
利用者ID2,パスワード2,合同会社テスト
クラス構成
EltaxBankCheckerクラス
-
setup_driver(): Chrome WebDriver設定(OS自動判定) -
login(): eLTAXログイン処理 -
navigate_to_bank_info(): 画面遷移処理 -
extract_bank_info(): 口座情報抽出 -
batch_check_all(): 全件バッチ処理 -
output_results(): Excel結果出力
実装のポイント
1. OS環境自動判定
system = platform.system()
if system == "Darwin": # Mac
chromedriver_path = "/opt/homebrew/bin/chromedriver"
elif system == "Windows":
chromedriver_path = "chromedriver.exe"
2. 複数セレクターパターン
user_id_selectors = [
(By.NAME, "sUserId"),
(By.ID, "sUserId"),
(By.CSS_SELECTOR, "input[name='sUserId']"),
]
3. 安全なエラーハンドリング
finally:
if driver:
try:
driver.quit()
except:
pass
gc.collect() # メモリ解放
実行方法
1. ファイル配置
project/
├── eltax_checker.py # メインスクリプト
└── 納税者一覧.csv # 納税者情報
2. 実行
python eltax_checker.py
3. 実行画面
==================================================
eLTAX口座振替確認自動化システム
Windows/Mac対応版
==================================================
1. テスト実行(1件のみ)
2. 全件実行
3. 終了
選択してください (1/2/3):
4. 出力ファイル
-
口座振替確認結果_YYYYMMDD_HHMM.xlsx- 確認結果 -
eltax_check_YYYYMM.log- 実行ログ
取得できる情報例
✅ 設定済みの場合:
- ステータス: 本登録
- 登録日: 2025/03/28
- 金融機関名: 三菱UFJ銀行
- 支店名: 本店
- 口座名義人: 株式会社サンプル 代表取締役 田中太郎
- 口座種別: 1.普通
❌ 未設定の場合:
- ステータス: 未設定
運用での注意点
セキュリティ
- 認証情報の適切な管理(暗号化推奨)
- ログファイルのアクセス制限
- 実行環境のセキュリティ確保
パフォーマンス
- 3秒間隔での実行(サーバー負荷軽減)
- 夜間・早朝での実行推奨
- 大量処理時のメモリ使用量監視
エラー対応
- 個別エラー時も全体処理は継続
- 詳細ログでのトラブルシューティング
- サイト仕様変更時の修正対応
効果と応用
業務効率化効果
- 作業時間: 手動3-4時間 → 自動化0分(無人実行)
- 精度向上: 人的ミスの排除
- データ品質: 構造化された確実なデータ取得
他の応用例
- 電子申請システムの申請状況確認
- 各種行政手続きの進捗管理
- 金融機関サイトでの残高確認
まとめ
eLTAXの口座振替設定確認を完全自動化することで、税理士事務所の業務を大幅に効率化できます。Windows・Mac両対応で、実際の業務環境ですぐに活用可能です。
注意: 本システムは業務効率化を目的としています。各サイトの利用規約を遵守し、適切な実行間隔での運用を心がけてください。
【おまけ】開発時の課題と解決策
実際の開発過程で遭遇した技術的課題と解決方法を共有します。
1. ポップアップ検出の試行錯誤
課題: eLTAXサイトの「事前準備セットアップ完了」ポップアップが自動で閉じられない
最初の実装(失敗):
# 日本語テキストベースの検索 - 動作せず
close_button = driver.find_element(By.XPATH, "//button[text()='閉じる']")
CSS:contains()セレクター(失敗):
# Seleniumでは:contains()が使用不可
close_button = driver.find_element(By.CSS_SELECTOR, "button:contains('閉じる')")
# InvalidSelectorException が発生
HTMLソース解析による解決:
# 実際のHTMLを確認
<a class="dlog-button dlog-button-close" id="close-btn" onclick="elpkiconfirmPostAction('0')">閉じる</a>
# ID属性での確実な検出
close_button = driver.find_element(By.ID, "close-btn")
2. 入力フィールドのname属性問題
課題: 利用者IDと暗証番号の入力ができない
最初の推測(失敗):
# 表示テキストベースの推測 - 存在しないセレクター
user_id_field = driver.find_element(By.NAME, "利用者ID")
password_field = driver.find_element(By.NAME, "暗証番号")
HTMLソース確認による解決:
<!-- 実際のHTML -->
<input id="sUserId" name="sUserId" type="text">
<input id="sPwd" name="sPwd" type="password">
# 正しいname属性で解決
user_id_field = driver.find_element(By.NAME, "sUserId")
password_field = driver.find_element(By.NAME, "sPwd")
3. ChromeDriverクラッシュ問題
課題: Apple Silicon Mac環境でChromeDriverが頻繁にクラッシュ
エラーメッセージ:
selenium.common.exceptions.WebDriverException:
Message:
Stacktrace:
0 chromedriver 0x00000001005283e0 cxxbridge1$str$ptr + 2829900
解決策の検討順序:
- メモリ関連オプション追加:
chrome_options.add_argument('--memory-pressure-off')
chrome_options.add_argument('--max_old_space_size=4096')
- ヘッドレスモード無効化:
# デバッグ用にヘッドレスを一時的に無効化
# chrome_options.add_argument('--headless') # コメントアウト
- シークレットモード採用:
# パスワード保存ダイアログ等の干渉を回避
chrome_options.add_argument('--incognito')
chrome_options.add_experimental_option('prefs', {
'credentials_enable_service': False,
'profile.password_manager_enabled': False
})
4. 要素検出タイムアウト対策
課題: 要素の検出でTimeoutExceptionが頻発
段階的な解決アプローチ:
Step 1: 待機時間延長
# 5秒 → 15秒に延長
WebDriverWait(driver, 15).until(EC.presence_of_element_located(...))
Step 2: 複数セレクターパターンの実装
selectors = [
(By.XPATH, "//span[text()='納税メニュー']"),
(By.XPATH, "//span[contains(text(), '納税メニュー')]"),
(By.XPATH, "//*[contains(text(), '納税メニュー')]"),
]
for method, selector in selectors:
try:
element = WebDriverWait(driver, 5).until(
EC.element_to_be_clickable((method, selector))
)
element.click()
break
except TimeoutException:
continue
Step 3: ページソース併用方式
# DOM操作とページソース解析の両方で情報取得
page_source = driver.page_source
if "本登録" in page_source:
# DOM操作での詳細取得も試行
try:
tables = driver.find_elements(By.TAG_NAME, "table")
# ...
except:
# ページソースからの正規表現抽出にフォールバック
import re
bank_pattern = r'([あ-ん一-龯\w]+銀行)'
bank_matches = re.findall(bank_pattern, page_source)
5. 画面遷移のタイミング問題
課題: ボタンクリック後の画面読み込み完了タイミングが不安定
最初の実装(不安定):
login_button.click()
time.sleep(3) # 固定待機 - 不十分な場合がある
改善した実装:
login_button.click()
# 動的待機:特定要素の出現を待つ
WebDriverWait(driver, 30).until(
lambda d: "口座情報" in d.page_source or "メニュー" in d.page_source
)
# さらに安全のため少し待機
time.sleep(2)
6. CSV読み込み時の文字化け
課題: CSVファイルの日本語が文字化け
エラー発生:
# デフォルトエンコーディングで読み込み - 文字化け発生
df = pd.read_csv('納税者一覧.csv')
解決策:
# UTF-8明示指定
df = pd.read_csv('納税者一覧.csv', encoding='utf-8')
# または Excel保存時の BOM付きUTF-8 対応
df = pd.read_csv('納税者一覧.csv', encoding='utf-8-sig')
7. 大量処理時のメモリリーク対策
課題: 50件処理時にメモリ使用量が増大
対策実装:
def check_single_taxpayer(self, user_id, password, taxpayer_name):
driver = None
try:
driver = self.setup_driver()
# 処理...
finally:
# 確実にWebDriverを終了
if driver:
try:
driver.quit()
except:
pass # 終了時のエラーは無視
# GC実行を促進(大量処理時)
import gc
gc.collect()
8. Windows/Mac環境差異への対応
課題: ChromeDriverのパス設定が環境によって異なる
環境判定による分岐:
import platform
system = platform.system()
if system == "Darwin": # Mac
if os.path.exists("/opt/homebrew/bin/chromedriver"):
chromedriver_path = "/opt/homebrew/bin/chromedriver" # Apple Silicon
else:
chromedriver_path = "/usr/local/bin/chromedriver" # Intel Mac
elif system == "Windows":
chromedriver_path = "chromedriver.exe"
else:
chromedriver_path = "chromedriver"
try:
service = Service(chromedriver_path)
driver = webdriver.Chrome(service=service, options=chrome_options)
except:
# パスが見つからない場合はPATH検索
driver = webdriver.Chrome(options=chrome_options)
開発時のデバッグテクニック
- ページソース出力:
# 問題発生時にHTMLソースをファイル出力
with open('debug_page_source.html', 'w', encoding='utf-8') as f:
f.write(driver.page_source)
- スクリーンショット取得:
# エラー発生時の画面状況を確認
driver.save_screenshot('debug_screenshot.png')
- ステップ実行:
# 開発時は各ステップで一時停止
input("Enterキーを押して続行...") # デバッグ用
これらの試行錯誤を経て、最終的に安定動作する実装に到達しました。同様のシステムを開発される際の参考になれば幸いです。