#!/usr/bin/env python3 # vim: ft=python fileencoding=utf-8 sts=4 sw=4 et: # Copyright 2014-2016 Claude (longneck) # This file is part of qutebrowser. # # qutebrowser is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # qutebrowser is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with qutebrowser. If not, see . """Tool to import data from other browsers. Currently only importing bookmarks from Netscape Bookmark files is supported. """ import argparse def main(): args = get_args() if args.browser in ['chromium', 'firefox', 'ie']: import_netscape_bookmarks(args.bookmarks) def get_args(): """Get the argparse parser.""" parser = argparse.ArgumentParser( epilog="To import bookmarks from Chromium, Firefox or IE, " "export them to HTML in your browsers bookmark manager.") parser.add_argument('browser', help="Which browser?", choices=['chromium', 'firefox', 'ie'], metavar='browser') parser.add_argument('bookmarks', help="Bookmarks file") args = parser.parse_args() return args def import_netscape_bookmarks(bookmarks_file): """Import bookmarks from a NETSCAPE-Bookmark-file v1. Generated by Chromium, Firefox, IE and possibly more browsers """ import bs4 with open(bookmarks_file, encoding='utf-8') as f: soup = bs4.BeautifulSoup(f, 'html.parser') html_tags = soup.findAll('a') bookmarks = [] for tag in html_tags: if tag['href'] not in bookmarks: bookmarks.append('{tag.string} {tag[href]}'.format(tag=tag)) for bookmark in bookmarks: print(bookmark) if __name__ == '__main__': main()