ฉันจะรวบรวมบันทึกย่อและไฮไลต์ทั้งหมดจาก iBooks ได้อย่างไร


14

ฉันมีการเน้นและบันทึกย่อมากมายใน iBooks ที่ฉันได้อ่านและต้องการที่จะรวบรวมพวกเขาในรูปแบบที่ใช้งานง่ายและจัดการรูปแบบ (เช่นการเขียนบทความและคำพูดอ้างอิง)

ตัวอย่างเช่นฉันต้องการไฮไลต์เช่นนี้

เพื่อสร้างบางสิ่ง (เช่นใน CSV) เช่น

ฉันมีคุณค่าทางโภชนาการฉันผลไม้ - สิ่งที่ค้ำจุนฉันยังทำลายฉัน, 14, Tamburlane ส่วนหนึ่งและสอง, Christopher Marlowe, แอนโธนีบีดอว์สันเอ็ด, บลูมสเบอรี่, https://itun.es/us/qSrZ0.l

ฉันสามารถดูวิธีการทำสิ่งนี้ (เรียงลำดับ) อย่างขะมักเขม้นในแต่ละครั้งโดยใช้คุณสมบัติ "การแบ่งปัน" ของ iBook (หรือคัดลอกและวางแน่นอน) แต่ฉันไม่เห็นวิธีที่จะทำเป็นกลุ่มเลยสำหรับทุกคน จากบันทึกย่อของฉันจากหนังสือหรือแม้แต่หนังสือทั้งหมดของฉัน

มีวิธีการทำเช่นนี้กับ Apple Script หรือใช้ Automator เช่น? หรืออาจมีไฟล์ข้อความหรือ XML ที่มีบันทึกย่อของฉันและเน้นว่าฉันสามารถเขียนสคริปต์ (ใน Python, เด่นกว่า) เพื่อแยกวิเคราะห์


โซลูชันดังกล่าวปรากฎออกมา (เช่นในหลาย ๆ กรณี) คือให้ทิ้งแอปเปิลไว้เบื้องหลังและเปลี่ยนเป็น Kindle ซึ่งมีการสนับสนุนที่ดีสำหรับการส่งออกไฮไลท์และโน้ต
orome

คำตอบ:


11

iBooks ไม่มีการสนับสนุน AppleScript คำอธิบายประกอบจะถูกเก็บไว้ในแฟ้มข้อมูล SQLite~/Library/Containers/com.apple.iBooksX/Data/Documents/AEAnnotation/ :

คุณสามารถลองแยกวิเคราะห์ได้ คำตอบนี้ให้ลิงก์ไปยังDigestedซึ่งอ่านฐานข้อมูลนั้นแล้วให้คุณส่งออกคำอธิบายประกอบของคุณไปยัง Evernote แต่ฉันไม่ทราบว่าจะมีการจัดรูปแบบใดหรือถ้าคุณต้องการยุ่งกับ Evernote

ทางออกหนึ่งที่ง่าย (อาจจะ) คือการเปิดหนังสือใน iBooks สำหรับ iOS จากนั้นคุณสามารถส่งอีเมลคำอธิบายประกอบเป็นจำนวนมากถึงตัวคุณเอง

  1. เปิดหนังสือ
  2. กดปุ่ม "รายการ" เพื่อเปิดสารบัญ
  3. สลับไปที่แท็บ Notes
  4. กดปุ่ม Share
  5. เลือกแก้ไขบันทึกย่อ
  6. เลือกทั้งหมด
  7. แบ่งปันทางอีเมล

แก้ไข:

ที่จริงแล้วหลังจากอ่านความคิดเห็นบน redditแล้วดูเหมือนจะมีวิธีส่งออกทั้งหมดจาก iBooks บน OS X เช่นกัน:

คุณสามารถส่งออกบันทึกย่อของคุณในอีเมลจาก Notes -> เลือกทั้งหมด -> แชร์ (คุณต้องกดปุ่ม Ctrl ค้างไว้ในขณะที่คลิกขวาเพื่อรักษาการเลือกของคุณไว้) ส่วนที่ไฮไลต์ของคุณจะถูกคัดลอกไปยังอีเมลพร้อมโน้ตและจัดรูปแบบไว้อย่างดี น่าแปลกที่แอปพลิเคชั่น Mac ไม่สนใจว่าหนังสือจะมีการป้องกันการคัดลอกหรือไม่ - มันจะคัดลอกส่วนที่ไฮไลต์อยู่เสมอ แอปพลิเคชั่น iOS แยกแยะแน่นอน หากหนังสือของคุณได้รับการป้องกันการคัดลอกจะมีการแชร์เฉพาะชื่อบท น่าจะเป็นวิธีเดียวที่น่าเสียดาย : /

เมื่อใช้แทร็คแพดของแล็ปท็อปฉันต้องกดค้างไว้ctrl + shiftในขณะที่แตะแทร็คแพดเพื่อเปิดเมนูตามบริบทขณะที่ยังคงการเลือก


สิ่งนี้มีประโยชน์มาก ฉันยังคงห่างไกลจากการทำให้คำอธิบายประกอบเป็นรูปแบบ CSV หรือรูปแบบอื่นที่สะดวกสบาย ฉันไม่สามารถทำอะไรออกจากฐานข้อมูล SQL และจดหมายในขณะที่ดูดีไม่สามารถเข้าถึงได้ทางโปรแกรม
orome

เป็นแค่ฉันหรือไม่สามารถทำได้ใน iBooks รุ่นใหม่หรือไม่ ฉันไม่เห็นปุ่มแก้ไขโน้ตอีกต่อไป ในกรณีนี้ฉันจะส่งออกบันทึกย่อทั้งหมดได้อย่างไร
หลอดไส้

@incandescentman มีไว้สำหรับฉันใน iOS 8.4
เฟรด

1
@incandescentman ขั้นตอนที่กำหนดหมายเลขในคำตอบของฉันด้านบนนั้นสำหรับ iOS ส่วนสุดท้ายของคำตอบ - ส่วนหลัง "แก้ไข" - สำหรับ OS X ซึ่งยังใช้ได้กับฉันใน Yosemite
เฟรด

2
ดังนั้นตอนนี้ฉันอยู่บน el capitan แต่ทิศทางจากความคิดเห็น reddit นั้นยังใช้ได้สำหรับฉัน ฉันเดาว่ากระบวนการจะแตกต่างกันเล็กน้อยขึ้นอยู่กับว่าคุณใช้เมาส์หรือแทร็คแพด การใช้แล็ปท็อปโดยไม่มีแป้นพิมพ์ / เมาส์ภายนอกหลังจากที่ฉันได้เลือกข้อคิดเห็นโดยใช้การเลือกทั้งหมดฉันก็กด control + shift + tap บน trackpad ที่จะนำขึ้นนี้: หน้าจอ มีการเลือกความคิดเห็นข้ามบทต่างๆ
fred

3

ฉันเขียนสคริปต์เพื่อจุดประสงค์นี้ซึ่งแยกบันทึกย่อจาก Mac ของคุณและส่งออกไฟล์ส่งออกของ Evernote พร้อมสำหรับการคลิกสองครั้ง บางทีคุณสามารถแก้ไขสคริปต์ของฉันได้ถ้ามันไม่เหมาะกับวัตถุประสงค์ของคุณอย่างแม่นยำ

กล่าวโดยย่อคืออ่านฐานข้อมูล SQLite ใน: ./Library/Containers/com.apple.iBooksX/Data/Documents/BKLibrary ./Library/Containers/com.apple.iBooksX/Data/Documents/AEAnnotations

... และในกรณีนี้ส่งออกเป็นรูปแบบ. enex ของ Evernote

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. ติดตั้งฟรีเบราว์เซอร์ DB สำหรับ SQLite
  2. ไปที่โฟลเดอร์คำอธิบายประกอบ iBooks: ~/Library/Containers/com.apple.iBooksX/Data/Documents/AEAnnotation/
  3. คัดลอก.sqliteไฟล์ที่อื่น (เช่นเดสก์ท็อป) เพื่อรักษาความปลอดภัยดั้งเดิม
  4. เปิดไฟล์ด้วย DB Browser
  5. ค้นหาบันทึกในหนังสือเป้าหมายของคุณโดยเรียกดูข้อมูล
  6. กรองตาม ZANNOTATIONASSETID เพื่อแสดงเฉพาะโน้ตในหนังสือเป้าหมาย
  7. คัดลอกและวางคำอธิบายประกอบที่คุณต้องการลงใน Numbers หรือแอปพลิเคชันที่คุณต้องการ

ความสะดวกในการใช้งานที่โด่งดังของ Apple!
orome

@raxacoricofallapatorius: อย่างจริงจัง นั่นเป็นสิ่งที่ยากมากที่จะได้รับรายชื่อคำศัพท์ที่ฉันเน้น
กาวิน
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.