{"id":881,"date":"2023-11-02T23:53:38","date_gmt":"2023-11-02T14:53:38","guid":{"rendered":"https:\/\/blog.srytk.com\/aquei\/?p=881"},"modified":"2023-11-02T23:53:40","modified_gmt":"2023-11-02T14:53:40","slug":"firefox%e3%81%ae%e5%b1%a5%e6%ad%b4%e3%82%92%e4%bf%9d%e5%ad%98%e3%81%99%e3%82%8b","status":"publish","type":"post","link":"https:\/\/blog.srytk.com\/aquei\/881.html","title":{"rendered":"Firefox\u306e\u5c65\u6b74\u3092\u4fdd\u5b58\u3059\u308b"},"content":{"rendered":"\n<p>firefox\u3067\u8868\u793a\u3057\u305f\u30a6\u30a7\u30d6\u30da\u30fc\u30b8\u306e\u5c65\u6b74\u306f<a href=\"https:\/\/support.mozilla.org\/ja\/kb\/profiles-where-firefox-stores-user-data#w_purohuairunige-na-sareteiruqing-bao\">\u30d7\u30ed\u30d5\u30a1\u30a4\u30eb\u306eplaces.sqlite\u306b\u4fdd\u5b58\u3055\u308c\u3066\u3044\u308b<\/a>\u3002\u3057\u304b\u3057\u3001\u30c7\u30d5\u30a9\u30eb\u30c8\u8a2d\u5b9a\u3067\u306f180\u65e5\u524d\u4ee5\u4e0a\u306e\u5c65\u6b74\u306f\u6d88\u53bb\u3055\u308c\u308b\u3002\u304a\u305d\u3089\u304f\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u4e0a\u306e\u7406\u7531\u304b\u30d7\u30e9\u30a4\u30d0\u30b7\u30fc\u4e0a\u306e\u7406\u7531\u306a\u3093\u3060\u308d\u3046\u3002<\/p>\n\n\n\n<p>\u3057\u304b\u3057\u3001\u8868\u793a\u30da\u30fc\u30b8\u306e\u5c65\u6b74\u306f\u904e\u53bb\u306e\u81ea\u5206\u306e\u8208\u5473\u95a2\u5fc3\u3092\u8868\u3059\u3001\u8a00\u308f\u3070<strong>\u65e5\u8a18<\/strong>\u306e\u3088\u3046\u306a\u30c7\u30fc\u30bf\u306a\u306e\u3067\u51fa\u6765\u308c\u3070\u6b8b\u3057\u3066\u8d77\u304d\u305f\u3044\u3002\u6614\u306b\u3088\u304f\u898b\u3066\u3044\u305f\u30a6\u30a7\u30d6\u30b5\u30a4\u30c8\u3068\u304b\u308f\u304b\u3063\u305f\u3089\u61d0\u304b\u3057\u304f\u3066\u9762\u767d\u305d\u3046\u3060\u3002places.sqlite\u306f\u5358\u306a\u308bsqlite\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u30d5\u30a1\u30a4\u30eb\u306a\u306e\u3067\u7c21\u5358\u306b\u30c7\u30fc\u30bf\u3092\u30a8\u30af\u30b9\u30dd\u30fc\u30c8\u3067\u304d\u308b\u3002\u4ee5\u4e0b\u306epython\u30b9\u30af\u30ea\u30d7\u30c8\u306f\u5c65\u6b74(\u30bf\u30a4\u30c8\u30eb\u3001URL\u3001\u30bf\u30a4\u30e0\u30b9\u30bf\u30f3\u30d7\u3001description)\u3092CSV\u3068\u3057\u3066\u8868\u793a\u3059\u308b\u30b5\u30f3\u30d7\u30eb\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>#!\/usr\/bin\/env python3\n\nimport sqlite3\nfrom pathlib import Path\nfrom io import StringIO\nimport csv\nimport argparse\n\ndef get_profile_history(profile_dir, min_time):\n    profile = Path(profile_dir)\n    db = profile \/ 'places.sqlite'\n    connection = sqlite3.connect(db)\n    connection.row_factory = sqlite3.Row\n\n    cur = connection.cursor()\n\n    query = \"\"\"\n    SELECT\n        moz_historyvisits.visit_date AS visit_date,\n        moz_places.url AS url,\n        moz_places.title AS title,\n        moz_places.description AS description\n    FROM\n        'moz_historyvisits'\n        LEFT OUTER JOIN\n            moz_places\n        ON  moz_historyvisits.place_id = moz_places.id\n    WHERE\n        visit_date > ?\n\"\"\"\n    \n    cur.execute(query, (min_time,))\n    return cur\n\n\ndef row2csv(d):\n    fieldnames = ('title', 'url', 'description', 'visit_date')\n    with StringIO(newline='') as s:\n        writer = csv.DictWriter(s, fieldnames=fieldnames)\n        writer.writeheader()\n        for h in d:\n            writer.writerow(dict(h))\n\n        return s.getvalue()\n\n\ndef get_args():\n    parser = argparse.ArgumentParser()\n    parser.add_argument('profile_dir', help='path to firefox profile')\n    parser.add_argument('min_time', help='min microsec timestamp', default=0)\n\n    return parser.parse_args()\n\n\nif __name__ == '__main__':\n    args = vars(get_args())\n    history = get_profile_history(**args)\n    print(row2csv(history))<\/code><\/pre>\n\n\n\n<p>\u6570\u5e74\u5f8c\u3068\u304b\u306b\u3001\u300c\u3042\u3042\u3001\u3053\u306e\u30b5\u30a4\u30c8\u3088\u304f\u898b\u3066\u305f\u306a\u3041\u300d\u3068\u304b\u601d\u3044\u305f\u3044\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>firefox\u3067\u8868\u793a\u3057\u305f\u30a6\u30a7\u30d6\u30da\u30fc\u30b8\u306e\u5c65\u6b74\u306f\u30d7\u30ed\u30d5\u30a1\u30a4\u30eb\u306eplaces.sqlite\u306b\u4fdd\u5b58\u3055\u308c\u3066\u3044\u308b\u3002\u3057\u304b\u3057\u3001\u30c7\u30d5\u30a9\u30eb\u30c8\u8a2d\u5b9a\u3067\u306f180\u65e5\u524d\u4ee5\u4e0a\u306e\u5c65\u6b74\u306f\u6d88\u53bb\u3055\u308c\u308b\u3002\u304a\u305d\u3089\u304f\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u4e0a\u306e\u7406\u7531\u304b\u30d7\u30e9\u30a4\u30d0\u30b7\u30fc\u4e0a\u306e\u7406\u7531\u306a\u3093\u3060 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"activitypub_content_warning":"","activitypub_content_visibility":"local","activitypub_max_image_attachments":5,"footnotes":""},"categories":[2],"tags":[218],"class_list":["post-881","post","type-post","status-publish","format-standard","hentry","category-tech","tag-firefox"],"_links":{"self":[{"href":"https:\/\/blog.srytk.com\/aquei\/wp-json\/wp\/v2\/posts\/881","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.srytk.com\/aquei\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.srytk.com\/aquei\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.srytk.com\/aquei\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.srytk.com\/aquei\/wp-json\/wp\/v2\/comments?post=881"}],"version-history":[{"count":3,"href":"https:\/\/blog.srytk.com\/aquei\/wp-json\/wp\/v2\/posts\/881\/revisions"}],"predecessor-version":[{"id":884,"href":"https:\/\/blog.srytk.com\/aquei\/wp-json\/wp\/v2\/posts\/881\/revisions\/884"}],"wp:attachment":[{"href":"https:\/\/blog.srytk.com\/aquei\/wp-json\/wp\/v2\/media?parent=881"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.srytk.com\/aquei\/wp-json\/wp\/v2\/categories?post=881"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.srytk.com\/aquei\/wp-json\/wp\/v2\/tags?post=881"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}