{"id":20055668,"url":"https://github.com/tsukumijima/isdbscanner","last_synced_at":"2025-09-17T15:57:06.860Z","repository":{"id":189398658,"uuid":"679734919","full_name":"tsukumijima/ISDBScanner","owner":"tsukumijima","description":"受信可能な日本のテレビチャンネル (ISDB-T/ISDB-S) を全自動でスキャンし、スキャン結果を様々な形式で出力するツール","archived":false,"fork":false,"pushed_at":"2025-06-07T20:53:38.000Z","size":383,"stargazers_count":50,"open_issues_count":0,"forks_count":1,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-06-07T21:24:16.611Z","etag":null,"topics":["dtv","isdb","linux"],"latest_commit_sha":null,"homepage":"","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/tsukumijima.png","metadata":{"files":{"readme":"Readme.md","changelog":null,"contributing":null,"funding":null,"license":"License.txt","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2023-08-17T13:53:46.000Z","updated_at":"2025-06-07T20:53:41.000Z","dependencies_parsed_at":"2023-08-19T20:41:34.948Z","dependency_job_id":"7433edaa-d922-4eb6-8fc6-06cd86e020d0","html_url":"https://github.com/tsukumijima/ISDBScanner","commit_stats":null,"previous_names":["tsukumijima/isdbscanner"],"tags_count":13,"template":false,"template_full_name":null,"purl":"pkg:github/tsukumijima/ISDBScanner","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/tsukumijima%2FISDBScanner","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/tsukumijima%2FISDBScanner/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/tsukumijima%2FISDBScanner/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/tsukumijima%2FISDBScanner/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/tsukumijima","download_url":"https://codeload.github.com/tsukumijima/ISDBScanner/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/tsukumijima%2FISDBScanner/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":275622396,"owners_count":25498326,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-09-17T02:00:09.119Z","response_time":84,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["dtv","isdb","linux"],"created_at":"2024-11-13T12:49:04.234Z","updated_at":"2025-09-17T15:57:06.853Z","avatar_url":"https://github.com/tsukumijima.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"\n# ISDBScanner\n\n![Screenshot](https://github.com/tsukumijima/ISDBScanner/assets/39271166/a60871ed-3fb8-4a6b-9b3e-41a3ccb63362)\n\n**受信可能な日本のテレビチャンネル (ISDB-T/ISDB-S) を全自動でスキャンし、スキャン結果を [EDCB](https://github.com/xtne6f/EDCB) ([EDCB-Wine](https://github.com/tsukumijima/EDCB-Wine))・[Mirakurun](https://github.com/Chinachu/Mirakurun)・[mirakc](https://github.com/mirakc/mirakc) の各設定ファイルや JSON 形式で出力するツールです。**\n\nお使いの Linux PC に接続されているチューナーデバイスを自動的に検出し、全自動で受信可能なすべての地上波・BS・CS チャンネルをスキャンします。  \n**実行時に `--exclude-pay-tv` オプションを指定すれば、CS と BS の有料放送をスキャン結果から除外することも可能です。**  \n**さらに PC に接続されている対応チューナーを自動的に認識し、Mirakurun / mirakc のチューナー設定ファイルとして出力できます。**\n\n地上波では、13ch 〜 62ch までの物理チャンネルをすべてスキャンして、お住まいの地域で受信可能なチャンネルを検出します。  \nBS・CS では、**BS・CS1・CS2 ごとに1つの物理チャンネルのみをスキャンし TS 内のメタデータを解析することで、他のチャンネルスキャンツールよりも高速に現在放送中の衛星チャンネルを検出できます。**\n\n\u003e [!NOTE]  \n\u003e 日本のテレビ放送は、主に地上波 (ISDB-T) と衛星放送 (ISDB-S) の2つの方式で行われています。  \n\u003e さらに、衛星放送は BS (Broadcasting Satellite) と CS (Communication Satellite) の2つの方式があります。   \n\u003e 各放送媒体を区別するため、各媒体には一意なネットワーク ID が割り当てられています。  \n\u003e\n\u003e 地上波放送では、居住地域によって受信可能な放送局が異なる特性上、放送局ごとにネットワーク ID が割り当てられています。  \n\u003e BS 放送では、すべて同じネットワーク ID (0x0004) が割り当てられています。  \n\u003e CS 放送では歴史的経緯から、CS1 (0x0006: 旧プラット・ワン系) と CS2 (0x0007: スカイパーフェクTV!2系) で異なるネットワーク ID が割り当てられています。  \n\u003e 具体的には、物理チャンネル ND02 / ND08 / ND10 内で放送されているチャンネルは CS1 ネットワーク、それ以外は CS2 ネットワークになります。現在両者の表面的な違いはほとんどありませんが、技術的には異なるネットワークとして扱われています。\n\u003e\n\u003e BS・CS (衛星放送) では、**同一ネットワークに属するすべてのチャンネルの情報が、放送波の MPEG-2 TS 内の NIT (Network Information Table) や SDT (Service Description Table) というメタデータに含まれています。**  \n\u003e そのため、**BS・CS1・CS2 の各ネットワークごとに1つの物理チャンネルをスキャンするだけで、そのネットワークに属するすべてのチャンネルを一括で検出できます。**\n\u003e \n\u003e さらに NIT に含まれる「現在放送中の BS/CS 物理チャンネルリスト」の情報を元にチャンネル設定ファイルを出力するため、**将来 BS 帯域再編 (トランスポンダ/スロット移動) が行われた際も、再度 ISDBScanner でチャンネルスキャンを行い、出力されたチャンネル設定ファイルを反映するだけで対応できます。**\n\n\u003e [!NOTE]  \n\u003e 地上波の物理チャンネルのうち 53ch - 62ch はすでに廃止されていますが、依然として一部ケーブルテレビのコミュニティチャンネル (自主放送) にて利用されているため、スキャン対象に含めています。\n\n\u003e [!IMPORTANT]  \n\u003e 検証環境がないため、ISDB-T の C13 - C63ch (周波数変換パススルー方式) と、ISDB-C (トランスモジュレーション方式) で放送されているチャンネルのスキャンには対応していません。 \n\n- [ISDBScanner](#isdbscanner)\n  - [対応チューナー](#対応チューナー)\n    - [chardev 版ドライバ](#chardev-版ドライバ)\n    - [DVB 版ドライバ](#dvb-版ドライバ)\n  - [対応出力フォーマット](#対応出力フォーマット)\n  - [インストール](#インストール)\n  - [使い方](#使い方)\n    - [PC に接続されている利用可能なチューナーのリストを表示](#pc-に接続されている利用可能なチューナーのリストを表示)\n    - [チャンネルスキャンを実行](#チャンネルスキャンを実行)\n  - [注意事項](#注意事項)\n  - [License](#license)\n\n## 対応チューナー\n\n[px4_drv](https://github.com/tsukumijima/px4_drv) / [smsusb (Linux カーネル標準ドライバ)](https://github.com/torvalds/linux/tree/master/drivers/media/usb/siano) 対応チューナー以外での動作は検証していませんが、おそらく動作すると思います。\n\n\u003e [!IMPORTANT]  \n\u003e **DVB 版ドライバを利用するには、ISDBScanner v1.1.0 / [recisdb](https://github.com/kazuki0824/recisdb-rs) v1.2.0 以降が必要です。**  \n\u003e recisdb v1.2.0 以前のバージョンは DVB 版ドライバの操作に対応していません。\n\n### chardev 版ドライバ\n\n- [px4_drv](https://github.com/tsukumijima/px4_drv)\n  - PLEX PX-W3U4\n  - PLEX PX-Q3U4\n  - PLEX PX-W3PE4\n  - PLEX PX-Q3PE4\n  - PLEX PX-W3PE5\n  - PLEX PX-Q3PE5\n  - PLEX PX-MLT5PE\n  - PLEX PX-MLT8PE\n  - PLEX PX-M1UR\n  - PLEX PX-S1UR\n  - e-better DTV02A-1T1S-U\n  - e-better DTV02A-4TS-P\n  - e-better DTV03A-1TU\n- [pt1_drv](https://github.com/stz2012/recpt1/tree/master/driver)\n  - Earthsoft PT1\n  - Earthsoft PT2\n- [pt3_drv](https://github.com/m-tsudo/pt3)\n  - Earthsoft PT3\n\n### DVB 版ドライバ\n\n動作検証は smsusb + VASTDTV VT20 のみ行っています。  \nほかの PX-S1UD 同等品 (Siano SMS2270 採用チューナー) シリーズであれば同様に動作するはずです。\n\nISDB-T / ISDB-S 対応であれば smsusb 以外のドライバ ([PT1・PT2](https://github.com/torvalds/linux/tree/master/drivers/media/pci/pt1) / [PT3](https://github.com/torvalds/linux/tree/master/drivers/media/pci/pt3) の DVB 版ドライバや [dddvb](https://github.com/DigitalDevices/dddvb) など) でも動作するはずですが、検証はできていません。  \n\n- [smsusb (Linux カーネル標準ドライバ)](https://github.com/torvalds/linux/tree/master/drivers/media/usb/siano)\n  - PLEX PX-S1UD\n  - PLEX PX-Q1UD\n  - MyGica S880i\n  - MyGica S270 (PLEX PX-S1UD 同等品)\n  - VASTDTV VT20 (PLEX PX-S1UD 同等品)\n\n## 対応出力フォーマット\n\nISDBScanner は、引数で指定されたディレクトリ以下に複数のファイルを出力します。  \n出力されるファイルのフォーマットは以下の通りです。\n\n\u003e [!NOTE]  \n\u003e **`--exclude-pay-tv` オプションを指定すると、Channels.json を除き、すべての出力ファイルにおいて有料放送チャンネルの定義が除外されます。**  \n\u003e なお、Channels.json に限り、BS 放送のみ常に有料放送チャンネルも含めた結果が出力されます (CS 放送はチャンネルスキャン処理自体が省略されるため出力されない) 。\n\n- **Channels.json**\n  - スキャン時に内部的に保持しているトランスポートストリームとサービスの情報を JSON 形式で出力します。\n  - 出力される JSON のデータ構造は [constants.py](https://github.com/tsukumijima/ISDBScanner/blob/master/isdb_scanner/constants.py#L8-L77) 内の実装を参照してください。\n  - BS/CS の周波数やトランスポンダ番号などかなり詳細な情報が出力されるため、スキャン結果を自作ツールなどで加工したい場合にはこのファイルを利用することをおすすめします。\n- **EDCB-Wine**\n  - **出力されるファイルはいずれも [EDCB-Wine](https://github.com/tsukumijima/EDCB-Wine) + [Mirakurun](https://github.com/Chinachu/Mirakurun)/[mirakc](https://github.com/mirakc/mirakc) + [BonDriver_mirakc](https://github.com/tkmsst/BonDriver_mirakc) を組み合わせた環境での利用を前提としています。**\n  - EDCB のチャンネル設定ファイルには、ChSet4.txt と ChSet5.txt という2つのフォーマットがあります。\n    - 両者とも中身は TSV で、各行にチャンネル設定データが記述されています。詳細なフォーマットは [formatter.py](https://github.com/tsukumijima/ISDBScanner/blob/master/isdb_scanner/formatter.py#L105-L266) の実装を参照してください。\n    - ChSet4.txt には、ファイル名に対応する BonDriver ”単体” で受信可能なチャンネルの情報が記述されています。\n      - **ISDBScanner で生成される ChSet4.txt は BonDriver_mirakc / BonDriver_Mirakurun 専用です。**\n      - それ以外の BonDriver で使う際は、別途 ChSet4.txt 内の物理チャンネルの通し番号やチューナー空間番号の対応を変更する必要があります。\n    - ChSet5.txt には、EDCB に登録されている BonDriver 全体で受信可能なチャンネルの情報が記述されています。\n  - EDCB-Wine (EpgTimerSrv) のチューナー割り当て/チューナー不足判定のロジックが正常に作動しなくなる可能性があるため、**BonDriver_mirakc(_T/_S).dll のチューナー数割り当ては、Mirakurun/mirakc に登録したチューナーの数と種類 (地上波専用/衛星専用/地上波衛星共用) に合わせることを強く推奨します。**\n  - **BonDriver_mirakc_T(BonDriver_mirakc).ChSet4.txt**\n    - EDCB 用のチャンネル設定ファイルです。EDCB-Wine + Mirakurun/mirakc + BonDriver_mirakc の組み合わせの環境での利用を前提にしています。\n    - **地上波のみのチャンネル設定データが含まれます。**\n      - 別途 BonDriver_mirakc.dll を BonDriver_mirakc_T.dll にコピーすることで、**BonDriver_mirakc_T.dll を地上波専用の Mirakurun/mirakc 用 BonDriver にすることができます。**\n      - PX-W3U4・PX-W3PE4 などの地上波チューナーと衛星チューナーが分かれている機種をお使いの環境では、**EpgTimerSrv のチューナー数設定で Mirakurun/mirakc に登録している地上波チューナーの数だけ BonDriver_mirakc_T.dll に割り当てることで、EDCB 上で地上波チューナーと衛星チューナーを分けて利用できます。**\n  - **BonDriver_mirakc_S(BonDriver_mirakc).ChSet4.txt**\n    - **BS・CS (衛星放送) のみのチャンネル設定データが含まれます。**\n      - 別途 BonDriver_mirakc.dll を BonDriver_mirakc_S.dll にコピーすることで、**BonDriver_mirakc_S.dll を衛星 (BS・CS) 専用の Mirakurun/mirakc 用 BonDriver にすることができます。**\n      - PX-W3U4・PX-W3PE4 などの地上波チューナーと衛星チューナーが分かれている機種をお使いの環境では、**EpgTimerSrv のチューナー数設定で Mirakurun/mirakc に登録している衛星チューナーの数だけ BonDriver_mirakc_S.dll に割り当てることで、EDCB 上で地上波チューナーと衛星チューナーを分けて利用できます。**\n  - **BonDriver_mirakc(BonDriver_mirakc).ChSet4.txt**\n    - **地上波・BS・CS すべてのチャンネル設定データが含まれます。**\n      - このチャンネル設定ファイルを合わせて使うことで、**BonDriver_mirakc.dll を地上波・衛星 (BS・CS) 共用の Mirakurun/mirakc 用 BonDriver にすることができます。**\n      - PX-MLT5PE などの地上波チューナーと衛星チューナーが統合されている機種 (マルチチューナー) をお使いの環境では、**EpgTimerSrv のチューナー数設定で Mirakurun/mirakc に登録しているマルチチューナーの数だけ BonDriver_mirakc.dll に割り当てることで、EDCB 上で適切にマルチチューナーを利用できます。**\n  - **ChSet5.txt**\n    - **ChSet4.txt と異なり、登録されている BonDriver のいずれかで受信可能な、地上波・BS・CS すべてのチャンネル設定データが含まれます。**\n    - 各チューナー (BonDriver) に依存するチャンネル情報は ChSet4.txt の方に書き込まれます。\n- **Mirakurun**\n  - **channels.yml**\n    - Mirakurun のチャンネル設定ファイルです。地上波・BS・CS すべてのチャンネル設定データが含まれます。\n    - **`channel` プロパティに記述されている物理チャンネル名は、[recisdb](https://github.com/kazuki0824/recisdb-rs) が受け入れる物理チャンネル指定フォーマット (T13 ~ T62 / BS01_0 ~ BS23_3 / CS02 ~ CS24) に対応しています。**\n      - **recpt1 の物理チャンネル指定フォーマットとは互換性がありません。**\n      - recpt1 をチューナーコマンドとして使用している場合は、代わりに channels_recpt1.yml を利用してください。\n  - **channels_recpt1.yml**\n    - Mirakurun のチャンネル設定ファイルです。地上波・BS・CS すべてのチャンネル設定データが含まれます。\n    - **`channel` プロパティに記述されている物理チャンネル名は、[recpt1](https://github.com/stz2012/recpt1) が受け入れる物理チャンネル指定フォーマット (13 ~ 62 / BS01_0 ~ BS23_3 / CS2 ~ CS24) に対応しています。**\n      - **recisdb の物理チャンネル指定フォーマットとは互換性がありません。**\n      - recisdb をチューナーコマンドとして使用している場合は、代わりに channels.yml を利用してください。\n  - **tuners.yml**\n    - Mirakurun のチューナー設定ファイルです。\n    - ISDBScanner で自動検出された、PC に接続されているすべてのチューナーの情報が含まれます。\n    - **`command` プロパティに記述されているチューナーコマンドには、[recisdb](https://github.com/kazuki0824/recisdb-rs) の `tune` サブコマンドが設定されています。**\n      - recpt1 をチューナーコマンドとして使用している場合は、代わりに tuners_recpt1.yml を利用してください。\n  - **tuners_recpt1.yml**\n    - Mirakurun のチューナー設定ファイルです。\n    - ISDBScanner で自動検出された、PC に接続されているすべてのチューナーの情報が含まれます。\n    - **`command` プロパティに記述されているチューナーコマンドには、[recpt1](https://github.com/stz2012/recpt1) コマンドが設定されています。**\n      - recisdb をチューナーコマンドとして使用している場合は、代わりに tuners.yml を利用してください。\n      - recpt1 に加え、`decoder` として arib-b25-stream-test コマンドが導入されていることを前提としています。\n      - recisdb と異なり recpt1 は DVB 版ドライバに対応していないため、DVB デバイスは記述から除外されます。\n- **mirakc**\n  - **config.yml**\n    - mirakc の設定ファイルです。\n    - `channels` セクションには、地上波・BS・CS すべてのチャンネル設定データが含まれます。\n      - **`channel` プロパティに記述されている物理チャンネル名は、[recisdb](https://github.com/kazuki0824/recisdb-rs) が受け入れる物理チャンネル指定フォーマット (T13 ~ T62 / BS01_0 ~ BS23_3 / CS02 ~ CS24) に対応しています。**\n        - **recpt1 の物理チャンネル指定フォーマットとは互換性がありません。**\n        - recpt1 をチューナーコマンドとして使用している場合は、代わりに config_recpt1.yml を利用してください。\n    - `tuners` セクションには、ISDBScanner で自動検出された、PC に接続されているすべてのチューナーの情報が含まれます。\n      - **`command` プロパティに記述されているチューナーコマンドには、[recisdb](https://github.com/kazuki0824/recisdb-rs) の `tune` サブコマンドが設定されています。**\n        - recpt1 をチューナーコマンドとして使用している場合は、代わりに config_recpt1.yml を利用してください。\n  - **config_recpt1.yml**\n    - mirakc の設定ファイルです。\n    - `channels` セクションには、地上波・BS・CS すべてのチャンネル設定データが含まれます。\n      - **`channel` プロパティに記述されている物理チャンネル名は、[recpt1](https://github.com/stz2012/recpt1) が受け入れる物理チャンネル指定フォーマット (13 ~ 62 / BS01_0 ~ BS23_3 / CS2 ~ CS24) に対応しています。**\n        - **recisdb の物理チャンネル指定フォーマットとは互換性がありません。**\n        - recisdb をチューナーコマンドとして使用している場合は、代わりに config.yml を利用してください。\n    - `tuners` セクションには、ISDBScanner で自動検出された、PC に接続されているすべてのチューナーの情報が含まれます。\n      - **`command` プロパティに記述されているチューナーコマンドには、[recpt1](https://github.com/stz2012/recpt1) コマンドが設定されています。**\n        - recisdb をチューナーコマンドとして使用している場合は、代わりに config.yml を利用してください。\n      - recpt1 に加え、`decode-filter` として arib-b25-stream-test コマンドが導入されていることを前提としています。\n      - recisdb と異なり recpt1 は DVB 版ドライバに対応していないため、DVB デバイスは記述から除外されます。\n\n## インストール\n\nISDBScanner は、チューナー受信コマンドとして [recisdb](https://github.com/kazuki0824/recisdb-rs) を利用しています。  \nそのため、事前に recisdb のインストールが必要です。\n\n\u003e [!NOTE]  \n\u003e **[recisdb](https://github.com/kazuki0824/recisdb-rs) は、旧来から chardev 版ドライバ用チューナー受信コマンドとして利用されてきた [recpt1](https://github.com/stz2012/recpt1) と、標準入出力経由で B25 デコードを行う [arib-b25-stream-test](https://www.npmjs.com/package/arib-b25-stream-test) / [b25 (libaribb25 同梱)](https://github.com/tsukumijima/libaribb25) のモダンな代替として開発された、次世代の Rust 製チューナー受信コマンドです。**  \n\u003e \n\u003e チューナーからの放送波の受信と B25 デコード、さらに信号レベルの確認 (checksignal) をすべて recisdb ひとつで行えます。  \n\u003e さらに recpt1 と異なり BS の物理チャンネルがハードコードされていないため、**将来 BS 帯域再編 (トランスポンダ/スロット移動) が行われた際も、recisdb を更新することなく ISDBScanner でのチャンネルスキャンと各設定ファイルの更新だけで対応できます。**\n\n以下の手順で、recisdb をインストールしてください。  \n下記は recisdb v1.2.3 時点でのインストール手順です。 \n\n```bash\n# Deb パッケージは Ubuntu 20.04 LTS / Debian 11 以降に対応\n\n# x86_64 環境\nwget https://github.com/kazuki0824/recisdb-rs/releases/download/1.2.3/recisdb_1.2.3-1_amd64.deb\nsudo apt install ./recisdb_1.2.3-1_amd64.deb\nrm ./recisdb_1.2.3-1_amd64.deb\n\n# arm64 環境\nwget https://github.com/kazuki0824/recisdb-rs/releases/download/1.2.3/recisdb_1.2.3-1_arm64.deb\nsudo apt install ./recisdb_1.2.3-1_arm64.deb\nrm ./recisdb_1.2.3-1_arm64.deb\n```\n\u003e [!NOTE]  \n\u003e アンインストールは `sudo apt remove recisdb` で行えます。\n\nISDBScanner 自体は Python スクリプトですが、Python 3.11 がインストールされていない環境でも動かせるよう、PyInstaller でシングルバイナリ化した実行ファイルを公開しています。  \n下記は ISDBScanner v1.3.2 時点でのインストール手順です。\n\n```bash\n# x86_64 環境\nsudo wget https://github.com/tsukumijima/ISDBScanner/releases/download/v1.3.2/isdb-scanner -O /usr/local/bin/isdb-scanner\nsudo chmod +x /usr/local/bin/isdb-scanner\n\n# arm64 環境\nsudo wget https://github.com/tsukumijima/ISDBScanner/releases/download/v1.3.2/isdb-scanner-arm -O /usr/local/bin/isdb-scanner\nsudo chmod +x /usr/local/bin/isdb-scanner\n```\n\n## 使い方\n\n![Screenshot](https://github.com/user-attachments/assets/ff759d35-b902-47f6-aeb4-18e5949bee30)\n\nISDBScanner は、引数で指定されたディレクトリ (デフォルト: `./scanned/`) 以下に複数のファイルを出力します。  \n出力される各ファイルのフォーマットは [対応出力フォーマット](#対応出力フォーマット) を参照してください。\n\n\u003e [!IMPORTANT]\n\u003e **重要: ISDBScanner v1.3.0 以降を recisdb + px4_drv 環境で使う場合は、[tsukumijima/px4_drv](https://github.com/tsukumijima/px4_drv) かつ v0.4.0 以降に更新する必要があります。**  \n\u003e ISDBScanner v1.3.0 からは、px4_drv の chardev 版デバイスと全ての DVB 版デバイスで、**BS チャンネルを物理チャンネル番号（スロット番号・相対 TS 番号）ではなく、TSID (Transport Stream ID) で選局するように変更されました。**  \n\u003e TSID で選局することで、2025年2月末の帯域再編のように放送局側が通知なしに相対 TS 番号を変更した場合でも、受信できなくなる問題を防げます。  \n\u003e ただし、オリジナルの [nns779/px4_drv](https://github.com/nns779/px4_drv) は TSID での選局に対応していないため、**ISDBScanner が生成した設定ファイルを使うには、px4_drv をフォーク版である [tsukumijima/px4_drv](https://github.com/tsukumijima/px4_drv) に更新する必要があります。**  \n\u003e なお、PT1/PT2/PT3 の chardev 版ドライバは TSID での選局に対応していないため、これらのチューナー向けには TSID 選局の設定は生成されません。  \n\u003e また、[stz2012/recpt1](https://github.com/stz2012/recpt1) は TSID での選局に対応していないため、recpt1 向けの設定ファイルでは TSID での選局は行いません。\n\n\u003e [!TIP]\n\u003e **ISDBScanner v1.2.0 以降では、`--lnb` オプションを指定すると、衛星放送受信時にチューナーからアンテナに給電できます（動作未確認）。**  \n\u003e `--lnb 11v` と `--lnb 15v` の両方を指定できますが、px4_drv 対応チューナーには `--lnb 15v` のみ指定できます。  \n\u003e 明示的に LNB 給電を無効化するには、`--lnb low` を指定します。何も指定されなかったときは LNB 給電を行いません。\n\n### PC に接続されている利用可能なチューナーのリストを表示\n\n![Screenshot](https://github.com/tsukumijima/ISDBScanner/assets/39271166/99a9fcd4-0afb-4c42-914a-d284fb3cf057)\n\n`isdb-scanner --list-tuners` と実行すると、PC に接続されている、利用可能なチューナーのリストが表示されます。  \nチューナーが現在使用中の場合、チューナー情報の横に `(Busy)` と表示されます。\n\nPC に接続したはずのチューナーが認識されていない場合は、チューナードライバのインストール・ロード状態や、チューナーとの物理的な接続状況を確認してみてください。\n\n\u003e [!NOTE]  \n\u003e チューナーは chardev 版デバイスが先に認識され、DVB 版デバイスは後に認識されます。  \n\u003e chardev 版デバイスと DVB 版デバイスが同時に接続されている場合、chardev 版デバイスの方を優先してチャンネルスキャンに使用します。\n\n### チャンネルスキャンを実行\n\n地上波・BS・CS すべてのチャンネルをスキャンする際は、`isdb-scanner` と実行してください。  \n出力先ディレクトリを指定しない場合は `./scanned/` に出力されます。  \n\n地上波と BS の無料放送のみをスキャン結果に含めたい場合は、`isdb-scanner --exclude-pay-tv` と実行してください。\n\n\u003cimg align=\"center\" width=\"49%\" src=\"https://github.com/tsukumijima/ISDBScanner/assets/39271166/d54dd1c9-0ad8-40a0-9678-60f5a1ea8fc6\"\u003e\n\u003cimg align=\"center\" width=\"49%\" src=\"https://github.com/tsukumijima/ISDBScanner/assets/39271166/59368ddb-38b4-40fe-9c7f-7aee39828d13\"\u003e\n\u003cbr\u003e\u003cbr\u003e\n\n**チャンネルスキャン中は、検出されたトランスポートストリーム / チャンネル (サービス) のリストとスキャンの進捗状況が、リアルタイムでグラフィカルに表示されます。**  \nチャンネルスキャンに使おうとしたチューナーが現在使用中の際は、自動的に空いているチューナーを選択してスキャンを行います。  \nもし地上波で特定のチャンネルが受信できていない場合は、停波中でないかや受信状態などを確認してみてください。\n\nなお、チャンネルスキャンには地デジ・BS・CS のフルスキャンを行う場合で 6 分程度、地デジ・BS の無料放送のみをスキャンする場合で 5 分半程度かかります。  \nコマンドを実行した後は終わるまで放置しておくのがおすすめです。\n\n\u003e [!IMPORTANT]  \n\u003e **地上波で複数の中継局の電波を受信できる地域にお住まいの場合、同一のチャンネルが重複して検出されることがあります。**  \n\u003e この場合、ISDBScanner は同一のチャンネルを放送している各物理チャンネルごとに信号レベルを計測し、最も受信状態の良い物理チャンネルのみを選択します。動作確認はできていないけどおそらく動くはず…？  \n\n\u003e [!NOTE]  \n\u003e 出力される Mirakurun / mirakc のチューナー設定ファイルには、現在 PC に接続中のチューナーのみが記載されます。  \n\u003e 接続しているはずのチューナーが記載されない (ISDBScanner で認識されていない) 場合は、カーネルドライバのロード状態や、物理的なチューナーの接続状態を確認してみてください。\n\n## 注意事項\n\n- **すでに Mirakurun / mirakc を導入している環境でチャンネルスキャンを行う際は、できるだけ Mirakurun / mirakc を停止してから行ってください。**\n  - ISDBScanner は Mirakurun / mirakc を経由せず、recisdb を通してダイレクトにチューナーデバイスにアクセスします。  \n    **チャンネルスキャンと Mirakurun / mirakc による EPG 更新や録画のタイミングが重なると、チューナー数次第ではチューナーが不足してスキャンに失敗する可能性があります。**\n  - 録画中でないことを確認の上一旦 Mirakurun / mirakc サービスを停止し、ほかのソフトにチューナーを横取りされない状況でスキャンすることをおすすめします。  \n    スキャン完了後は停止した Mirakurun / mirakc サービスの再開を忘れずに。\n- **EDCB-Wine のチャンネル設定ファイルを実稼働環境に反映する場合は、EDCB-Wine で利用している Mirakurun / mirakc のチャンネル設定ファイルも、必ず同時に更新してください。**\n  - BonDriver は物理チャンネル自体の数値ではなく基本 0 からの連番となる「通し番号」でチャンネル切り替えを行う仕様になっていて、ChSet4.txt にはこの通し番号が記載されています。\n    - EDCB-Wine で利用している BonDriver_mirakc の場合、Mirakurun / mirakc 側で登録した物理チャンネルの配列インデックスがそのまま「通し番号」になります。\n  - つまり、**Mirakurun / mirakc のチャンネル設定ファイルを変更して登録中の物理チャンネルを増減させると、この BonDriver の「通し番号」がズレてしまい、再度 ChSet4.txt を生成し直さない限り正しくチャンネル切り替えが行えない状態に陥ります。**\n    - 実際私はこれが原因で録画に失敗したことがあります…。\n    - こうした事態を避けるため、**EDCB-Wine と Mirakurun / mirakc のチャンネル設定ファイルは、片方だけを更新するのではなく、常に両方を同時に更新するようにしてください。**\n- **深夜にチャンネルスキャンを行うと、停波中のチャンネルがスキャン結果から漏れてしまいます。**\n  - 特に NHK Eテレは毎日深夜に放送を休止しているため、深夜にスキャンを行うとスキャン結果から漏れてしまいます。\n  - できるだけ (停波中のチャンネルがない) 日中時間帯でのチャンネルスキャンをおすすめします。\n\n## License\n\n[MIT License](License.txt)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ftsukumijima%2Fisdbscanner","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Ftsukumijima%2Fisdbscanner","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ftsukumijima%2Fisdbscanner/lists"}