iBooksからすべてのノートとハイライトを収集するにはどうすればよいですか?


14

私が読んだiBooksには多くのハイライトとメモがあり、それらを簡単に使用および操作できる1つの形式で収集できるようにしたいと思います(たとえば、論文の執筆や引用の引用など)。

たとえば、このようなハイライトが欲しい

次のようなものを作成する(CSVなど)

QUOD私nutrit私destruit - 。、14、Tamburlaneパート1と2、クリストファー・マーロウ、アンソニーB.ドーソン編をも私を支えて私を破壊すること、ブルームズベリー、https://itun.es/us/qSrZ0.l

iBookの「共有」機能(またはコピーと貼り付け)を使用して、一度に1つずつメモを作成する方法(面倒な作業)を見ることができますが、一括して行う方法はありません。本のメモ、またはすべての本のメモ。

Apple ScriptやAutomatorなどを使用して、これを達成する方法はありますか?または、メモやハイライトを含むテキストまたはXMLファイルがあり、解析するスクリプトを(できればPythonで)書くことができます。


解決策は、(多くの場合)Appleを残してKindleに切り替えることであることが判明しました。これは、ハイライトやメモのエクスポートを強力にサポートしています。
オロメ

回答:


11

iBooksはAppleScriptをサポートしていません。注釈は、SQLiteのファイルに保存されます~/Library/Containers/com.apple.iBooksX/Data/Documents/AEAnnotation/

あなたはそれを解析しようとすることができます。この回答Digestedへのリンクを提供します。Digestedはそのデータベースを読み取り、注釈をEvernoteにエクスポートできますが、どのフォーマットを使用するか、またはEvernoteを台無しにしたいかどうかはわかりません。

1つの(おそらく)簡単な解決策は、iOS用のiBooksで本を開くことです。その後、注釈を一括して自分宛にメールで送信できます。

  1. 本を開いてください
  2. 「リストボタン」を押して目次を表示します
  3. [メモ]タブに切り替えます
  4. 共有ボタンを押します
  5. [メモを編集]を選択します
  6. すべて選択
  7. メールで共有します。

編集:

実際、redditについてのコメントを読んだ後、OS X上のiBooksからそれらすべてをエクスポートする方法があるようです:

電子メールでメモをエクスポートするには、[メモ]-> [すべて選択]-> [共有]を選択します(選択を保持するには、右クリック中にctrlキーを押す必要があります)。強調表示された部分は、メモとともにメールにコピーされ、適切にフォーマットされます。奇妙なことに、Macでは、アプリケーションは書籍がコピー保護されているかどうかを気にしません。ハイライトされた部分を常にコピーします。iOSアプリケーションは確かに差別します。書籍がコピー保護されている場合、章名のみが共有されます。残念ながらそれが唯一の方法だと思われます。:/

ラップトップのトラックパッドを使用してctrl + shift、選択を保持したままコンテキストメニューを表示するには、トラックパッドを押しながら押し続ける必要がありました。


これは非常に役立ちます。ただし、注釈をCSVやその他の便利な形式に変換する方法はまだありません。SQLデータベースから何かを作成することはできません。メールは見栄えは良いですが、プログラムからアクセスできません。
オロム14

それは私だけですか、それともiBooksの新しいバージョンではこれは不可能ですか?[ノートの編集]ボタンはもう表示されません。その場合、ノートをすべてエクスポートするにはどうすればよいですか?
白熱

@incandescentman iOS 8.4には私のためにあります。
フレッド

1
@incandescentman上記の私の答えの番号付きのステップはiOS向けでした。答えの最後の部分である「編集」の後のセクションは、OS Xに関するものです。それはYosemiteでも引き続き機能します。
フレッド

2
だから、私は今エルキャピタンにいますが、そのredditコメントからの指示はまだ私のために働いています。マウスとトラックパッドのどちらを使用しているかによって、プロセスは少し異なると思います。外部キーボード/マウスなしでラップトップを使用し、「すべて選択」を使用してコメントを選択した後、トラックパッドでCtrl + Shift +タップを押します。これがスクリーンショットです。章全体のコメントが選択されます。
フレッド

3

この目的のために、Macからメモを抽出し、Evernoteエクスポートファイルを出力するスクリプトを作成しました。おそらく、目的に正確に合わない場合は、私のスクリプトを変更できます。

つまり、。/ Library / Containers / com.apple.iBooksX / Data / Documents / BKLibrary ./Library/Containers/com.apple.iBooksX/Data/Documents/AEAnnotationsのSQLiteデータベースを読み取ります。

...この場合、それらをEvernoteの.enex形式にエクスポートします。

https://github.com/jorisw/ibooks2evernote/

    <?php
    /*
     *  iBooks notes to Evernote converter
     *  by Joris Witteman <joris@jor.is>
     *  
     *  Reads the iBooks Annotations library on your Mac and exports
     *  them, tagged with their respective book title and imported in
     *  separate notebooks.
     *
     *  Usage:
     *  
     *  Move this script to the top of your personal home directory on your Mac.
     *  This is the folder that has your name, which the Finder opens if you
     *  click on the Finder icon in the Dock.
     *
     *  To export your notes to Evernote:
     *  
     *  1. Run the following command in the Terminal:
     *
     *     php ./ibooks2evernote.php
     *    
     *  2. Open the newly created "iBooks exports for Evernote" folder from your
     *     home folder, open each file in there, Evernote will open and start 
     *     importing your notes.
     *
     */




















    // Default file locations for required iBooks data 
    define('RESULT_DIRECTORY_NAME',"iBooks exports for Evernote");
    define('BOOKS_DATABASE_DIRECTORY','./Library/Containers/com.apple.iBooksX/Data/Documents/BKLibrary');
    define('NOTES_DATABASE_DIRECTORY','./Library/Containers/com.apple.iBooksX/Data/Documents/AEAnnotation');


    if(file_exists(RESULT_DIRECTORY_NAME)){
        die("The destination folder for the exports already exists on your Mac.\nPlease move that one out of the way before proceeding.\n");
    }

    // Verify presence of iBooks database

    if(!file_exists(BOOKS_DATABASE_DIRECTORY)){
        die("Sorry, couldn't find an iBooks Library on your Mac. Have you put any books in there?\n");
    }else{
        if(!$path = exec('ls '.BOOKS_DATABASE_DIRECTORY."/*.sqlite")){
            die("Could not find the iBooks library database. Have you put any books in there?\n");
        }else{
            define('BOOKS_DATABASE_FILE',$path);
        }
    }


    // Verify presence of iBooks notes database

    if(!file_exists(NOTES_DATABASE_DIRECTORY)){
        die("Sorry, couldn't find any iBooks notes on your Mac. Have you actually taken any notes in iBooks?\n");
    }else{
        if(!$path = exec('ls '.NOTES_DATABASE_DIRECTORY."/*.sqlite")){
            die("Could not find the iBooks notes database. Have you actually taken any notes in iBooks?\n");
        }else{
            define('NOTES_DATABASE_FILE',$path);
        }
    }


    // Fire up a SQLite parser

    class MyDB extends SQLite3
    {
      function __construct($FileName)
      {
         $this->open($FileName);
      }
    }


    // Retrieve any books.

    $books = array();

    $booksdb = new MyDB(BOOKS_DATABASE_FILE);

    if(!$booksdb){
      echo $booksdb->lastErrorMsg();
    } 

    $res = $booksdb->query("
                SELECT
                    ZASSETID,
                    ZTITLE AS Title,
                    ZAUTHOR AS Author
                FROM ZBKLIBRARYASSET
                WHERE ZTITLE IS NOT NULL");

    while($row = $res->fetchArray(SQLITE3_ASSOC) ){
        $books[$row['ZASSETID']] = $row;
    }

    $booksdb->close();

    if(count($books)==0) die("No books found in your library. Have you added any to iBooks?\n");

    // Retrieve the notes.

    $notesdb = new MyDB(NOTES_DATABASE_FILE);

    if(!$notesdb){
      echo $notesdb->lastErrorMsg();
    } 

    $notes = array();

    $res = $notesdb->query("
                SELECT
                    ZANNOTATIONREPRESENTATIVETEXT as BroaderText,
                    ZANNOTATIONSELECTEDTEXT as SelectedText,
                    ZANNOTATIONNOTE as Note,
                    ZFUTUREPROOFING5 as Chapter,
                    ZANNOTATIONCREATIONDATE as Created,
                    ZANNOTATIONMODIFICATIONDATE as Modified,
                    ZANNOTATIONASSETID
                FROM ZAEANNOTATION
                WHERE ZANNOTATIONSELECTEDTEXT IS NOT NULL
                ORDER BY ZANNOTATIONASSETID ASC,Created ASC");

    while($row = $res->fetchArray(SQLITE3_ASSOC) ){
        $notes[$row['ZANNOTATIONASSETID']][] = $row;
    }

    $notesdb->close();


    if(count($notes)==0) die("No notes found in your library. Have you added any to iBooks?\n\nIf you did on other devices than this Mac, make sure to enable iBooks notes/bookmarks syncing on all devices.");


    // Create a new directory and cd into it

    mkdir(RESULT_DIRECTORY_NAME);
    chdir(RESULT_DIRECTORY_NAME);

    $i=0;
    $j=0;
    $b=0;

    foreach($notes as $AssetID => $booknotes){

        $Body = '<?xml version="1.0" encoding="UTF-8"?>
        <!DOCTYPE en-export SYSTEM "http://xml.evernote.com/pub/evernote-export3.dtd">
        <en-export export-date="'.@strftime('%Y%m%dT%H%M%S',time()).'" application="iBooks2Evernote" version="iBooks2Evernote Mac 0.0.1">';

        $BookTitle  = $books[$AssetID]['Title'];

        $j = 0;

        foreach($booknotes as $note){

            $CappedText = null;
            $TextWithContext = null;

            // Skip empty notes
            if(strlen($note['BroaderText']?$note['BroaderText']:$note['SelectedText'])==0) continue;

            $HighlightedText = $note['SelectedText'];

            // Cap the titles to 255 characters or Evernote will blank them.

            if(strlen($HighlightedText)>255) $CappedText = substr($note['SelectedText'],0,254)."…";

            // If iBooks stored the surrounding paragraph of a highlighted text, show it and make the highlighted text show as highlighted.
            if(!empty($note['BroaderText']) && $note['BroaderText'] != $note['SelectedText']){
                $TextWithContext = str_replace($note['SelectedText'],"<span style=\"background: yellow;\">".$note['SelectedText']."</span>",$note['BroaderText']);
            }

            // Keep some counters for commandline feedback
            if($j==0)$b++;
            $i++;
            $j++;

            // Put it in Evernote's ENEX format.
            $Body .='
    <note><title>'.($CappedText?$CappedText:$HighlightedText).'</title><content><![CDATA[<?xml version="1.0" encoding="UTF-8" standalone="no"?>
    <!DOCTYPE en-note SYSTEM "http://xml.evernote.com/pub/enml2.dtd">
    <en-note>
    <div>
    <p>'.($TextWithContext?$TextWithContext:$HighlightedText).'</p>
    <p><span style="color: rgb(169, 169, 169);font-size: 12px;">From chapter: '.$note['Chapter'].'</span></p>
    </div>
    <div>'.$note['Note'].'</div>
    </en-note>
    ]]></content><created>'.@strftime('%Y%m%dT%H%M%S',@strtotime("2001-01-01 +". ((int)$note['Created'])." seconds")).'</created><updated>'.@strftime('%Y%m%dT%H%M%S',@strtotime("2001-01-01 +". ((int)$note['Modified'])." seconds")).'</updated><tag>'.$BookTitle.'.</tag><note-attributes><author>joris@jor.is</author><source>desktop.mac</source><reminder-order>0</reminder-order></note-attributes></note>';

        }

        $Body .='
        </en-export>
        ';

        file_put_contents($BookTitle.".enex", $Body);
    }

    echo "Done! Exported $i notes into $b separate export files in the '".RESULT_DIRECTORY_NAME."' folder.\n\n";

3
  1. SQLite用の無料のDBブラウザーをインストールします。
  2. iBooksの注釈フォルダーに移動します。 ~/Library/Containers/com.apple.iBooksX/Data/Documents/AEAnnotation/
  3. .sqliteファイルをどこか(デスクトップなど)にコピーして、元のファイルを安全に保ちます。
  4. DBブラウザでファイルを開きます。
  5. データを参照して、ターゲットブック内のメモを見つけます。
  6. ZANNOTATIONASSETIDでフィルタリングして、ターゲットブック内のノートのみを表示します。
  7. 必要な注釈をコピーして、Numbersまたは任意のアプリケーションに貼り付けます。

アップルの有名な使いやすさ!
オロメ

@raxacoricofallapatorius:まじで。これは、私が強調した語彙のリストを取得するためのいくつかのリグマロールです。
ギャビン
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.