Export "Saved Stories" from Apple News to SQLite
Project description
apple-news-to-sqlite
Export Apple News Saved Stories to SQLite
Install
pip install apple-news-to-sqlite
Source code
Usage
apple-news-to-sqlite articles.db
apple-news-to-sqlite --dump
Your Terminal app will require full disk access in order to access the saved article database in the Apple News app sandbox.
CLI help
Usage: apple-news-to-sqlite [OPTIONS] [DB_PATH]
Export your Apple News saved stories/articles to a SQLite database
Example usage:
apple-news-to-sqlite articles.db
This will populate articles.db with an "articles" table containing information
about your saved articles.
Notes:
The contents of the articles themselves are not stored in the database, only
metadata about the article such as title, author, url, etc.
The date the article was saved is in GMT.
Options:
--version Show the version and exit.
--dump, --json Print saved stories to standard output as JSON.
--all Process all saved articles; if not specified, only saved
articles that have not previously been stored in the database
are processed.
--schema Create database schema and exit.
--help Show this message and exit.
Using apple-news-to-sqlite in your own Python code
get_saved_articles()
returns a list of dictionaries, each representing a saved article with the
following keys:
* id: str
* date: datetime.datetime
* url: str
* title: str
* description: str
* image: str
* author: str
>>> from apple_news_to_sqlite import get_saved_articles
>>> articles = get_saved_articles()
How it works
Through reverse engineering, it was determined that the Apple News app stores
saved articles in a file called reading-list
in the following directory:
~/Library/Containers/com.apple.news/Data/Library/Application Support/com.apple.news/com.apple.news.public-com.apple.news.private-production/
This format of this file is unknown but it is a binary file that contains two embedded binary plist files. The first contains an NSKeyedArchiver object which I have not yet inspected. The second bplist contains a list of saved article IDs along with the date they were saved. The article IDs are used to look up the article data on Apple's News site and the article data is extracted with Beautiful Soup.
Testing
The code is at the "it works on my machine" stage of testing. (M1 Mini, macOS Ventura 13.1)
I've also tested this on macOS Catalina 10.15.7 and it appears to work correctly.
If it doesn't work for you, please open an issue!
Contributing
Contributions of all types are welcome! Fork the repo, make a branch, and submit a PR.
See README_DEV.md for developer notes.
Thanks
Thanks to Simon Willison who inspired this project with his excellent "everything-to-sqlite" dogsheep project.
Thanks Simon also for the excellent tools sqlite-utils and Datasette.
Thanks also to Dave Bullock who inspired this project and helped tremendously with the reverse engineering and initial code.
License
MIT License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file apple_news_to_sqlite-0.5.2.tar.gz
.
File metadata
- Download URL: apple_news_to_sqlite-0.5.2.tar.gz
- Upload date:
- Size: 7.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 48a00bb9750fcbed8f13514238551ece65588eaedac811581134fac521f2d9e6 |
|
MD5 | c0e1817e3186b506e6f28866b2108df8 |
|
BLAKE2b-256 | 1657330539f7c8632d7f06e3b3f660780c755b1a5138f9821fdfd00b0d54ecff |
File details
Details for the file apple_news_to_sqlite-0.5.2-py3-none-any.whl
.
File metadata
- Download URL: apple_news_to_sqlite-0.5.2-py3-none-any.whl
- Upload date:
- Size: 8.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 996db85a87ce22ac2c2ccbc09d434d7e6d84f40cc2946640cd5483a94ae19d02 |
|
MD5 | 8c3d0e131c829eef8753a76f7044df16 |
|
BLAKE2b-256 | 7d11a858ce4169ad4beb5e6261ed78bbde18c342bc65b612009480b3385e5a5c |