データベースの API 説明書

この API はスレッドセーフです。(複数のリーダ、単一のライタのロック機構を使用) この API には次のようにしてアクセスできます:

from calibre.library import db
db = db('Path to calibre library folder').new_api

メインの calibre GUI の一部である calibre プラグインにいるなら、代わりに次のようにしてアクセスします:

db = self.gui.current_db.new_api
class calibre.db.cache.Cache(backend, library_database_instance=None)[ソース]

calibre ライブラリの metadata.db ファイルのメモリ内キャッシュ。このクラスはデータベースにアクセスするためのスレッドセーフな API としても機能します。メモリ内キャッシュは、性能を最大化するために通常の形式で維持されます。

SQLITE は metadata.db に安全に読み書きするための手段として使用されます。テーブルの読取り/並べ替え/検索/キャッシュのロジックが再実装されます。これは性能の最大化と柔軟性のために必要です。

class EventType(*values)
book_created = 4

本の ID を唯一の引数として新しい本のレコードをデータベースに作成するとき

book_edited = 8

次の引数とともに本の形式を編集するとき: (book_id, fmt)

books_removed = 5

本の ID を唯一の引数としてデータベースから本を削除するとき

format_added = 2

次の引数とともに本に形式を追加するとき: (book_id, format)

formats_removed = 3

次の引数とともに本から形式が削除されるとき: (book_id から、削除される本の形式のリストへのマッピング)

indexing_progress_changed = 9

インデックス処理の進行状況が変わったとき

items_removed = 7

タグや著者などの項目を一部の本から削除するとき。引数: (field_name, affected book ids, ids of removed items)

items_renamed = 6

タグや著者などの項目の名前を一部またはすべての本で変更するとき。引数: (field_name, affected book ids, map of old item id to new item id)

要素に関連するリンクを変更したとき。引数: (field_name, item_ids)

metadata_changed = 1

次の引数とともに一部の本で一部の書誌を変更するとき: (変更したフィールド名, 影響する本の ID のセット)

notes_changed = 10

要素に関連する注釈を変更したとき。引数: (field_name, item_ids)

add_books(books, add_duplicates=True, apply_import_tags=True, preserve_uuid=False, run_hooks=True, dbapi=None)[ソース]

指定した本をライブラリに追加。本は 2 タプルの繰り返し可能なもので、各 2 タプルは (mi, format_map) のフォームです。mi は Metadata オブジェクトで、format_map はフォーム {fmt: path_or_stream} の辞書です。例: {'EPUB': '/path/to/file.epub'}

リストのペア (ids, duplicates) を返します。ids にはデータベースに新しく作成されたすべての本の ID が含まれます。duplicates には、has_book() が使用する簡単な重複検出ヒューリスティックに従って、データベースにすでにある本の (mi, format_map) が含まれます。

add_custom_book_data(name, val_map, delete_first=False)[ソース]

name のデータを追加。val_map は book_ids の値へのマップです。delete_first が True のとき、以前格納していた name のデータはすべて削除されます。

add_extra_files(book_id, map_of_relpath_to_stream_or_path, replace=True, auto_rename=False)[ソース]

追加データファイルを追加

add_format(book_id, fmt, stream_or_path, replace=True, run_hooks=True, dbapi=None)[ソース]

指定した本に形式を追加します。形式が正常に追加された場合は True を返します。

パラメータ:
  • replace -- True のとき既存の形式を置き換え、そうでなければ形式がすでに存在しているときに False を返します。

  • run_hooks -- True のとき、追加の前後でファイルタイプのプラグインを形式に実行します。

  • dbapi -- 内部利用のみ。

add_listener(event_callback_function, check_already_added=False)[ソース]

このデータベースで特定のアクションが実行された後に呼び出されるコールバック関数を登録します。関数は 3 つの引数が必要です: (EventType, library_id, event_type_specific_data)

add_notes_resource(path_or_stream_or_data, name: str, mtime: float = None) int[ソース]

注釈を参照できるリソースを追加して、コンテンツハッシュを返します。

all_annotation_types()[ソース]

データベース中のすべての注釈をタプルで返します。

all_annotation_users()[ソース]

注釈を持つすべての(user_type, user name)をタプルで返します。

all_annotations(restrict_to_user=None, limit=None, annotation_type=None, ignore_removed=False, restrict_to_book_ids=None)[ソース]

基準に一致するすべての注釈をタプルで返します。ignore_removed  で移動(または削除)済の注釈を対象とするかどうかを制御します。移動済の注釈は注釈マージの枠としてだけ使用されます。

all_annotations_for_book(book_id)[ソース]

指定のbook_idですべての注釈を含むタプルを返します。辞書のKEYは: format, user_type, user, annotation ここのannotaionは注釈データです。

all_book_ids(type=<class 'frozenset'>)[ソース]

すべての既知の本の ID の凍結セット。

all_field_for(field, book_ids, default_value=None)[ソース]

field_for と同じですが、一度に複数の本を操作します

all_field_ids(name)[ソース]

フィールド name のすべての値の frozenset 。

all_field_names(field)[ソース]

すべてのフィールド名の凍結セット (多対 1 と多対多のフィールドにのみ使用)

annotation_count_for_book(book_id)[ソース]

データベース中の指定bookの注釈の個数を返します。

annotations_map_for_book(book_id, fmt, user_type='local', user='viewer')[ソース]

book_id, format, user, user_typeを指定して、annotation type -> annotation dataのmapを返します。

author_data(author_ids=None)[ソース]

著者データをキー付きの辞書として返します: name, sort, link

指定された ID を持つ著者が見つからない場合は、空の辞書が返されます。 a uthor_ids が None の場合、すべての著者のデータが返されます。

author_sort_from_authors(authors, key_func=<function make_change_case_func.<locals>.change_case>)[ソース]

著者のリストを指定して、著者の author_sort 文字列を返します。計算された文字列よりも、著者読みに関連付けられた著者の並べ替えを優先します。

books_for_field(name, item_id)[ソース]

item_id で指定される項目に関連付けられた本をすべて返します。ここで、項目はフィールド name に属しています。

戻り値は本の ID のセット、または項目かフィールドが存在しなければ空のセットです。

books_in_virtual_library(vl, search_restriction=None, virtual_fields=None)[ソース]

指定された仮想ライブラリ内の本のセットを返します

compress_covers(book_ids, jpeg_quality=100, progress_callback=None)[ソース]

指定した本の表紙画像を圧縮します。圧縮品質が 100 なら、可逆圧縮を実行します。それ以外は、不可逆圧縮を実行します。

進行状況のコールバックは、book_id と、処理されたそれぞれの本の新旧のサイズとともに呼び出されます。エラーが発生すると、新しいサイズはエラーの詳細を含む文字列になります。

copy_cover_to(book_id, dest, use_hardlink=False, report_file_size=None)[ソース]

オブジェクト dest のようなファイルに表紙をコピーします。表紙が存在しない場合、または dest が現在の表紙と同じファイルである場合には、False を返します。 dest にはパスを指定することも可能です。その場合、パスが現在のパスと異なる場合にのみ、表紙をコピーします (大文字と小文字は区別されます)。

copy_format_to(book_id, fmt, dest, use_hardlink=False, report_file_size=None)[ソース]

形式` fmt` をオブジェクト dest のようなファイルにコピーします。指定された形式が存在しない場合には、NoSuchFormat エラーを発生させます。 destには (ファイルへの) パスを指定することも可能です。その場合、パスが現在のパスと異なる場合にのみ、形式をコピーします (大文字と小文字は区別されます)。

cover(book_id, as_file=False, as_image=False, as_path=False, as_pixmap=False)[ソース]

表紙画像または None を返します。デフォルトでは表紙をバイト列で返します。

警告: as_path を使用すると、表紙が一時ファイルにコピーされ、一時ファイルへのパスが返されます。使い終わったら、一時ファイルを削除する必要があります。

パラメータ:
  • as_file -- True のとき、開いているファイルオブジェクト(SpooledTemporaryFile) として画像を返します

  • as_image -- True のとき、QImage オブジェクトとして画像を返します

  • as_pixmap -- Trueのとき、QPixmapオブジェクトでイメージを返します。

  • as_path -- True のとき、一時ファイルを指すパスとして画像を返します

data_for_find_identical_books()[ソース]

データベースにアクセスすることなくワーカープロセスで find_identical_books() を実装するのに使えるデータを返します。実装については db.utils を参照してください。

data_for_has_book()[ソース]

has_book() での使用に適したデータを返します。これは、db にアクセスすることなくワーカープロセスで has_book() を実装するために使用できます。

delete_annotations(annot_ids)[ソース]

指定のIDで注釈を削除します。

delete_custom_book_data(name, book_ids=())[ソース]

name で指定されたデータを削除します。デフォルトではすべてのデータを削除します。一部の本の ID のデータのみ削除したい場合には、本の ID のリストを渡します。

delete_trash_entry(book_id, category)[ソース]

ごみ箱のエントリを削除します。ここで、'b' は本、'f' はフォーマットです。.

embed_metadata(book_ids, only_fmts=None, report_error=None, report_progress=None)[ソース]

指定された book_ids のすべての形式の書誌を、データベース内の現在の書誌に更新します。

expire_old_trash()[ソース]

ゴミ箱の古いエントリを期限切れとします。

export_note(field, item_id) str[ソース]

埋め込み画像はdata: URLs として、注釈を単一HTMLドキュメントにエクスポートします。

fast_field_for(field_obj, book_id, default_value=None)[ソース]

field_for と同じですが、フィールドオブジェクトを取得するために余分な検索を回避します

field_for(name, book_id, default_value=None)[ソース]

book_id で指定された本のフィールド name の値を返します。そのような本が存在しない、またはフィールド名に定義された値がない、またはそのようなフィールドが存在しない場合、default_value が返されます。

default_value は、title、title_sort、authors、author_sort、series_indexには使用されません。これらは常にデータベースに値を持っているためです。 default_valueは、すべてのカスタム列に使用されます。

is_multiple フィールドの戻り値は、値が見つからない場合でも常にタプルです(つまり、default_value は無視されます)。例外は識別子で、その戻り値は常に辞書です。戻り値のタプルは常にリンク順、つまり作成順になります。

field_ids_for(name, book_id)[ソース]

book_id で識別されるブックのフィールド名の値の ID を (タプルとして) 返します。値がない、またはそのような本がない、またはそのようなフィールドがない場合は、空のタプルが返されます。

field_supports_notes(field=None) bool[ソース]

指定されたフィールドが注釈をサポートしている場合、Trueを返します。フィールドがNoneの場合、注釈をサポートするすべてのフィールドのfrozensetを返します。

find_identical_books(mi, search_restriction='', book_ids=None)[ソース]

mi に著者のスーパーセットがあり、タイトルが同じ本を検索します (タイトルはあいまい検索)。 data_for_find_identical_books() も参照のこと。

format(book_id, fmt, as_file=False, as_path=False, preserve_filename=False)[ソース]

電子書籍の形式をバイト列として返します。形式が存在しない場合、または電子書籍ファイルに書き込む権限がない場合は、None を返します。

パラメータ:
  • as_file -- True のとき、電子書籍の形式がファイルオブジェクトとして返されます。ただしファイルオブジェクトは SpooledTemporaryFile のため、形式を別のファイルにコピーする場合には、性能上の理由により、代わりに copy_format_to() を使用してください。

  • as_path -- 形式ファイルを一時ファイルにコピーし、一時ファイルへのパスを返します

  • preserve_filename -- True かつパスを返すとき、ファイル名はライブラリで使用されているものと同じです。ただしこれを使用すると、呼び出すたびに同じ一時ファイルを作成します (毎回作り直します)

format_abspath(book_id, fmt)[ソース]

format 形式の電子書籍ファイルへの絶対パスを返します。これはこのAPIのスレッドセーフの約束を破るため、原則的に使用すべきではありません。代わりに copy_format_to() を使用してください。

現在これを使用しているのは、calibredbリスト、ビューア、編集ブック、元の形式とのcompare_format、アプリケーションを指定して開く、一括書誌編集、およびカタログ (get_data_as_dict() 経由で) のみです。

ビューア、アプリケーションを指定して本を開く、本の編集を除き、この呼び出しの結果を使用してファイル書き込み I/O を実行する人はいないと思います。

format_hash(book_id, fmt)[ソース]

指定された本の指定された形式のハッシュを返します。ハッシュの種類はバックエンドに依存しますが、通常はSHA-256です。

format_metadata(book_id, fmt, allow_cache=True, update_db=False)[ソース]

指定した本の指定した形式のパス、サイズ、および mtime を返します。パスに直接アクセスするとこのAPIのスレッドセーフの保証が破られるため、絶対に必要な場合を除いてはパスを使用しないでください。代わりに、copy_format_to() メソッドを使用してください。

パラメータ:
  • allow_cache -- True のとき、キャッシュした値を使用します。そうでなければ遅いファイルアクセスが行われます。この API 以外からアクセスした場合、キャッシュ値が古い可能性があります。

  • update_db -- True` のとき、この本の max_size フィールドをデータベースで更新します

formats(book_id, verify_formats=True)[ソース]

指定された本のすべての形式のタプルを返します。 verify_formats が True の場合、ファイルがディスク上に存在することを検証します。

get_all_items_that_have_notes(field_name=None) set[int] | dict[str, set[int]][ソース]

指定されたフィールドに注釈があるアイテムのすべてのID一覧 を返します。field_name が None の場合はすべてのフィールドを返します。

book_idで識別される本が参照するすべてのフィールドのリンクをすべて返します。book_idが存在しない場合は、このメソッドは {} を返します。

例: 著者AにリンクX、著者BにリンクY、タグSにリンクF、タグTにリンクGがあるとします。本1に著者AとタグTがある場合、このメソッドは {'authors':{'A':'X'}, 'tags':{'T', 'G'}} を返します。本2の著者が著者Aでも著者Bでもなく、タグもない場合、このメソッドは {} を返します。

パラメータ:

book_id -- 問い合わせるbook ID

戻り値:

{field: {field_value, link_value}, ... 空でないリンク値を持つ field_value を持つすべてのフィールドについて

get_book_path(book_id, sep='/', unsafe=False)[ソース]

指定されたIDの本の相対パスを返します。ディレクトリセパレータを選択できるため、こちらの方が便利です。デフォルトではOSのセパレータが使用されます。unsafeがTrueの場合、book_idがライブラリに存在しない場合にNoneを返すことができます。

get_categories(sort='name', book_ids=None, already_fixed=None, first_letter_sort=False, uncollapsed_categories=None)[ソース]

タグブラウザの実装のために内部的に使用。

get_custom_book_data(name, book_ids=(), default=None)[ソース]

name のデータを取得します。デフォルトでは、すべての book_id のデータが返されます。一部のデータのみが必要な場合は、本の ID のリストを渡します。 book_id から値へのマップを返します。特定の値をデコードできなかった場合は、デフォルトを使用します。

get_id_map(field)[ソース]

指定したフィールドの ID 番号から値へのマッピングを返します。フィールドは多対1または多対多のフィールドである必要があります。そうでない場合、ValueErrorが発生します。

get_ids_for_custom_book_data(name)[ソース]

name がデータを持つ本の ID のセットを返します。

get_item_id(field, item_name, case_sensitive=False)[ソース]

item_name のアイテムIDを返します。見つからない場合はNoneを返します。get_item_ids()またはget_item_name_map()を使用して複数の名前を検索する場合、この関数は非常に遅くなります。同様に、大文字と小文字を区別する検索は、大文字と小文字を区別しない検索より高速です。

get_item_ids(field, item_names, case_sensitive=False)[ソース]

item_name をアイテム ID にマッピングする辞書または None を返します。

get_item_name(field, item_id)[ソース]

指定したフィールドの item_id で指定された項目の項目名を返します。get_id_map() も参照のこと。

get_item_name_map(field, normalize_func=None)[ソース]

アイテム値とIDのマッピングを返します。

指定されたフィールドのリンクの辞書を返します。

パラメータ:

for_field -- リンクマップが必要なフィールドの参照名

戻り値:

空でないリンクについて {field_value:link_value, ...}

get_metadata(book_id, get_cover=False, get_user_categories=True, cover_as_data=False)[ソース]

calibre.ebooks.metadata.book.base.Metadata オブジェクトとして book_id が指定する本の書誌を返します。ただし形式のリストは検証されません。 get_cover が True のとき、表紙が返されます。mi.coverとして一時ファイルへのパス、または cover_as_data が True であれば mi.cover_data として返されます。

get_next_series_num_for(series, field='series', current_indices=False)[ソース]

指定されたシリーズの次のシリーズインデックスを返します。このとき、次のシリーズ番号の生成を制御するさまざまな設定が考慮されます。

パラメータ:
  • field -- シリーズのようなフィールド (デフォルトはビルトインのシリーズ列)

  • current_indices -- True のとき、代わりに book_id から現在の series_index 値へのマッピングを返します。

get_notes_resource(resource_hash) dict | None[ソース]

リソースデータと名前を含む辞書を返すか、指定されたハッシュを持つリソースが見つからない場合はNoneを返します。

get_proxy_metadata(book_id)[ソース]

get_metadata() と同様ですが、オンデマンドでデータベースから値を読み取るだけの ProxyMetadata オブジェクトを返す点が異なります。これは、返された書誌オブジェクトから少数のフィールドにアクセスするだけでよい場合、 get_metadata よりもはるかに高速です。

get_usage_count_by_id(field)[ソース]

IDから、指定したフィールドのすべての値の使用回数へのマッピングを返します。これは、多対1または多対多のフィールドである必要があります。

has_book(mi)[ソース]

渡された Metadata オブジェクトと同じタイトルのエントリがデータベースに含まれていれば True を返します。比較で大文字と小文字は区別されません。data_for_has_book() も参照のこと。

has_format(book_id, fmt)[ソース]

ディスク上に形式が存在すれば True を返します。

has_id(book_id)[ソース]

指定した book_id が db に存在すれば True を返します

import_note(field, item_id, path_to_html_file, path_is_data=False)[ソース]

以前にエクスポートした注釈または任意の HTML ファイルを、指定したアイテムの注釈としてインポートします。

init()[ソース]

バックエンドからのデータでこのキャッシュを初期化します。

items_with_notes_in_book(book_id: int) dict[str, dict[int, str]][ソース]

指定された本のそのフィールドに関連付けられた注釈を持つ、フィールドの辞書を返します。

存在すれば指定されたアイテムのリンクを返します。存在しない場合は None を返します。

list_extra_files(book_id, use_cache=False, pattern='') tuple[ExtraFile, ...][ソース]

本のディレクトリ内に存在する追加ファイルの情報を取得します。

パラメータ:
  • book_id -- データベースの本のID

  • pattern -- 検索するファイル名のパターン。空のパターンは、すべての追加ファイルに一致します。パターンは/を区切り文字として使用します。データディレクトリ内のファイルに一致させるには、DATA_FILE_PATTERN 定数を使用してください。

戻り値:

指定されたパターンに一致するすべての追加ファイルのタプル。タプルの各要素は ExtraFile(relpath, file_path, stat_result) です。relpathは、/を区切り文字として使用した、本ディレクトリへのファイルの相対パスです。stat_resultは、ファイルに対して os.stat() を呼び出した結果です。

merge_annotations_for_book(book_id, fmt, annots_list, user_type='local', user='viewer')[ソース]

指定された注釈を、book_id、fm、user_type、および user の既存の注釈にマージします。

merge_extra_files(dest_id, src_ids, replace=False)[ソース]

src_ids から dest_id へ追加ファイルをマージします。ファイル名が衝突する時は、replace=True が指定されていない場合は自動的にファイル名を変更し、指定されている場合はファイルを置換します。

move_book_from_trash(book_id)[ソース]

ゴミ箱フォルダから本を復元します。

move_format_from_trash(book_id, fmt)[ソース]

ゴミ箱フォルダから形式を復元します。

multisort(fields, ids_to_sort=None, virtual_fields=None)[ソース]

並べ替えられた本の ID のリストを返します。ids_to_sort が None のとき、すべての ID を返します。

fields は、そのフォームの2 タプルのリストである必要があります (field_name、ascending=TrueまたはFalse)。最も重要なフィールドは最初の 2 タプルです。

notes_data_for(field, item_id) str[ソース]

すべての注釈データを辞書として返します。注釈が存在しない場合はNoneを返します。

notes_for(field, item_id) str[ソース]

注釈ドキュメントを返します。存在しない場合は空文字列を返します。

notes_resources_used_by(field, item_id)[ソース]

指定されたアイテムの注釈で使用されるすべてのリソースのハッシュのセットを返します。

pref(name, default=None, namespace=None)[ソース]

指定した環境設定の値、または環境設定に指定がなければデフォルト値を返します。

read_backup(book_id)[ソース]

本の OPF 書誌バックアップをバイト列として返します。バックアップが存在しない場合は None を返します。

remove_books(book_ids, permanent=False)[ソース]

book_ids で指定された本をデータベースから削除し、その形式ファイルも削除します。permanent がFalseの場合、形式ファイルはライブラリごとのゴミ箱ディレクトリに配置されます。

remove_extra_files(book_id: int, relpaths: Iterable[str], permanent=False) dict[str, Exception | None][ソース]

指定された追加ファイルをゴミ箱または完全に削除します。

remove_formats(formats_map, db_only=False)[ソース]

指定した本から指定した形式を削除します。

パラメータ:
  • formats_map -- book_id から、削除される本の形式のリストへのマッピング。

  • db_only -- True のとき、その形式のレコードを db からだけ削除し、ファイルシステムにある実際の形式ファイルは削除しません。

戻り値:

本IDと、その本のファイルシステムから実際に削除された形式とのマップ

remove_items(field, item_ids, restrict_to_book_ids=None)[ソース]

指定した ID を持つ指定したフィールドのすべてのアイテムを削除します。影響を受ける本の ID のセットを返します。 restrict_to_book_ids は、オプションの本の ID のセットです。指定すると、項目はそれらの本からのみ削除されます。

rename_extra_files(book_id, map_of_relpath_to_new_relpath, replace=False)[ソース]

追加データファイルを名称変更

rename_items(field, item_id_to_new_name_map, change_index=True, restrict_to_book_ids=None)[ソース]

タグやシリーズのような、多対多のフィールドから項目の名前を変更します。

パラメータ:
  • change_index -- シリーズのようなフィールドで名前を変更する場合は、series_index の値も変更します。

  • restrict_to_book_ids -- 名前の変更を実施しようとしている本の ID のセット。デフォルトではすべての本。

restore_book(book_id, mi, last_modified, path, formats, annotations=())[ソース]

ファイルシステムにすでに存在する本の、データベース内のエントリを復元します

restore_original_format(book_id, original_fmt)[ソース]

以前に保存した ORIGINAL_FORMAT に指定した形式があれば、復元します。成功時に True を返します。復元が成功すると ORIGINAL_FORMAT は削除されます。

property safe_read_lock

安全な読み取りロックは、スレッドがすでに書き込みロックを持っている場合は何もせず、そうでない場合に読み取りロックを取得するロックです。これは、複合列が存在するときに検索キャッシュを更新すると発生する可能性がある DowngradeLockErrors を防ぐために必要です。検索キャッシュを更新すると排他ロックが保持されますが、複合列を検索するには、共有ロックを取得しようとする ProxyMetadata を介してフィールド値を読み取る必要があります。これのトリガーとなる別のシナリオもあるかもしれません。

このプロパティは、アクセスごとに新しいロックオブジェクトを返します。このロックオブジェクトは (性能上の理由で) 再帰的ではなく、必ず with cache.safe_read_lock: として with 文とともに使用する必要があります。そうしないと、よくないことが起こります。

save_original_format(book_id, fmt)[ソース]

指定した形式のコピーを ORIGINAL_FORMAT として保存し、既存の ORIGINAL_FORMAT を上書きします。

search(query, restriction='', virtual_fields=None, book_ids=None)[ソース]

指定したクエリをデータベースで検索し、マッチした本のIDのセットを返します。

パラメータ:
  • restriction -- 指定したクエリに AND される制限。ただし制限がキャッシュされるため、AND bの 検索は、制限 b よりも遅くなります。

  • virtual_fields -- 内部使用 (検索する on_device のような仮想フィールド)

  • book_ids -- None でないとき、すべての本を検索するのではなく、検索される本の ID のセット。

search_annotations(fts_engine_query, use_stemming=True, highlight_start=None, highlight_end=None, snippet_size=None, annotation_type=None, restrict_to_book_ids=None, restrict_to_user=None, ignore_removed=False)[ソース]

指定された全文検索クエリに一致する注釈をタプルで返します。

search_notes(fts_engine_query='', use_stemming=True, highlight_start=None, highlight_end=None, snippet_size=None, restrict_to_fields=(), return_text=True, result_type=<class 'tuple'>, process_each_result=None, limit=None)[ソース]

FTSインデックスを使用して注釈のテキストを検索します。クエリが空の場合は、すべての注釈を返します。

set_annotations_for_book(book_id, fmt, annots_list, user_type='local', user='viewer')[ソース]

指定された book_id、fmt、user_type、および user のすべての注釈を設定します。

set_conversion_options(options, fmt='PIPE')[ソース]

options は、{book_id:conversion_options} 形式のマップでなくてはなりません

set_cover(book_id_data_map)[ソース]

この本の表紙を設定します。データは、QImage、QPixmap、ファイルオブジェクト、またはバイト列のいずれかです。 None にすることも可能で、その場合、既存の表紙はすべて削除されます。

set_field(name, book_id_to_val_map, allow_case_change=True, do_path_update=True)[ソース]

name で指定したフィールドの値を設定します。変更の影響を受けたすべての本 の IDのセットを返します。

パラメータ:
  • book_id_to_val_map -- book_id から、適用すべき値へのマッピング。

  • allow_case_change -- True のとき、多対1または多対多フィールドの大文字と小文字が変更されます。たとえば、本にタグ tag1 があり、別の本のタグを Tag1 に設定した場合、allow_case_change が True であれば両方の本にタグ Tag1 が付けられ、そうでなければ両方にタグ tag1 が付けられます。

  • do_path_update -- 内部利用。決して変更しないこと。

フィールド内のアイテム値のリンクを設定します。注意: このメソッドは value_to_link_map にない値は変更しません。

パラメータ:
  • field -- ルックアップ名称

  • value_to_link_map -- dict(field_value:link, ...) 引数はフィールドIDでなく、値であることに注意してください

戻り値:

リンクを設定することで変更された本

set_metadata(book_id, mi, ignore_errors=False, force_changes=False, set_title=True, set_authors=True, allow_case_change=False)[ソース]

Metadata オブジェクト mi からの本 id の本に書誌を設定します

force_changes= True を設定すると、miに空の値が含まれていても、強制的に set_metadata を更新します。この場合、'None' と 'empty' は区別されます。 mi.XXX が None のとき XXX は置き換えられませんが、そうでなければ置き換えられます。タグ、識別子、および表紙属性は特殊なケースです。タグと識別子は None に設定できないため、force_changes が true の場合は常に置き換えられます。mi には本に持たせたい値が必ず含まれるようにしてください。新しい表紙が提供されると表紙は常に変更されますが、削除されることはありません。なお、force_changes はタイトルや著者の設定には影響しません。

set_notes_for(field, item_id, doc: str, searchable_text: str = '', resource_hashes=(), remove_unused_resources=False) int[ソース]

注釈のドキュメントを設定します。検索可能なテキストがドキュメントと異なる場合は、searchable_text で指定してください。ドキュメントがリソースを参照している場合は、そのハッシュを resource_hashes に設定する必要があります。未使用のリソースをクリーンアップするには、remove_unused_resources を True に設定します。注釈を更新すると、その注釈に関連するリソースも自動的にクリーンアップされることに注意してください。

set_pref(name, val, namespace=None)[ソース]

指定した環境設定に指定した値を設定します。pref() も参照のこと。

split_if_is_multiple_composite(f, val)[ソース]

f が複合列の参照キーであり、列が is_multiple の場合、v を一意の空でない値に分割します。比較では大文字と小文字が区別されます。順序は保持されません。proxy metadata field getters(例:tags)との互換性のため、list() を返します。

tags_older_than(tag, delta=None, must_have_tag=None, must_have_authors=None)[ソース]

指定した時間より古いタグ tag を持つすべての本の ID を返します。tag の比較で大文字と小文字は区別されません。

パラメータ:
  • delta -- timedelta オブジェクト、または None。None のときにはそのタグの ID がすべて返されます。

  • must_have_tag -- None でないとき、マッチするリストはこのタグが付いた本に制限されます

  • must_have_authors -- 著者のリスト。 None でないとき、マッチするリストは指定された著者の本に制限されます (大文字と小文字は区別されません)。

unretire_note_for(field, item_id) int[ソース]

指定されたアイテムの、以前に廃止された注釈を復元します。注釈は、アイテムがデータベースから削除されたときに廃止されます。

update_annotations(annot_id_map)[ソース]

注釈の更新

user_categories_for_books(book_ids, proxy_metadata_map=None)[ソース]

指定した本のユーザカテゴリを返します。 proxy_metadata_map はオプションで、本の ProxyMetadata オブジェクトがすでに存在するコンテキストでパフォーマンスを向上させるのに役立ちます。これは、book_idsから対応するProxyMetadataオブジェクトへのマッピングでないといけません。