Skip to main content

Convert AddressBook database (.abcddb) to Contacts VCards file (.vcf)

Project description

abcddb2vcard

This python script reads an AddressBook database file (AddressBook-v22.abcddb) and export its content to a vCard file (.vcf).

I created this script to automate my contacts backup procedure. The output of this script should be exactly the same as dragging and dropping the "All Contacts" card.

Installation

To install abcddb2vcard from PyPi, use pip:

pip install abcddb2vcard

abcddb2vcard can then be used from any working directory in the Terminal.

To uninstall:

pip uninstall abcddb2vcard

Usage

Export all contacts

abcddb2vcard backup/contacts_$(date +"%Y-%m-%d").vcf

Export into individual files

abcddb2vcard outdir -s 'path/%{fullname}.vcf'

Extract contact images

vcard2img AllContacts.vcf ./profile_pics/

Usage help

abcddb2vcard

usage: abcddb2vcard [-h] [-f] [--dry-run] [-i AddressBook.abcddb] [-s FORMAT]
                    outfile.vcf

Extract data from AddressBook database (.abcddb) to Contacts VCards file
(.vcf)

positional arguments:
  outfile.vcf           VCard output file.

optional arguments:
  -h, --help            show this help message and exit
  -f, --force           Overwrite existing output file.
  --dry-run             Do not write file(s), just print filenames.
  -i AddressBook.abcddb, --input AddressBook.abcddb
                        Specify another abcddb input file. Default:
                        ~/Library/Application Support/AddressBook/AddressBook-v22.abcddb
  -s FORMAT, --split FORMAT
                        Output into several vcf files instead of a single
                        file. File format can use any field of type Record.
                        E.g. "%{id}_%{fullname}.vcf".

vcard2img

usage: vcard2img [-h] infile.vcf outdir

Extract all profile pictures from a Contacts VCards file (.vcf)

positional arguments:
  infile.vcf  VCard input file.
  outdir      Output directory.

optional arguments:
  -h, --help  show this help message and exit

Supported data fields

  • firstname
  • lastname
  • middlename
  • nameprefix
  • namesuffix
  • nickname
  • maidenname
  • phonetic_firstname
  • phonetic_middlename
  • phonetic_lastname
  • phonetic_organization
  • organization
  • department
  • jobtitle
  • birthday
  • [email]
  • [phone]
  • [address]
  • [socialprofile]
  • note
  • [url]
  • [xmpp-service]
  • image
  • iscompany

Limitations

Currently, the image field only supports JPG images. But as far as I see, Apple converts PNG to JPG before storing the image. If you encounter a db which includes other image types, please let me know.

Disclaimer

You should check the output for yourself before using it in a production environment. I have tested the script with many arbitrary fields, however there may be some edge cases missing. Feel free to create an issue for missing or wrong field values.

Note: The output of diff or FileMerge.app can be different to this output. Apple uses some data transformations (on vcf export) which are not only unnecessary but may break the re-import of the file.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

abcddb2vcard-1.2.2.tar.gz (11.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

abcddb2vcard-1.2.2-py3-none-any.whl (12.2 kB view details)

Uploaded Python 3

File details

Details for the file abcddb2vcard-1.2.2.tar.gz.

File metadata

  • Download URL: abcddb2vcard-1.2.2.tar.gz
  • Upload date:
  • Size: 11.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for abcddb2vcard-1.2.2.tar.gz
Algorithm Hash digest
SHA256 7ca206375da97e1e2425abb93555f6fd52d6ccf4abadfbd9d0914726e6f6ac28
MD5 de36de60db5666944a1776b6f856b35b
BLAKE2b-256 f3dc4dc2b710204611bdb2ea345e626d622c69a8538e91a5ca45feeaa8b58f07

See more details on using hashes here.

File details

Details for the file abcddb2vcard-1.2.2-py3-none-any.whl.

File metadata

  • Download URL: abcddb2vcard-1.2.2-py3-none-any.whl
  • Upload date:
  • Size: 12.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for abcddb2vcard-1.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 8a5e2f00d745c1663250325e1668f5c9e45d03262befebdd5bee49c358cf45e0
MD5 e319dd9d262efda1addec23b7a844902
BLAKE2b-256 0d20c8b7eae75f20e0b89cf51185672f68d9e26bde6c295f4ad8b42744d8ff4d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page