WizNote 迁出记录

2019-06-15  本文已影响0人  ToddLee

实在是受不了 WizNote mac 版本到现在都没有markdown 功能,而且搜索莫名其妙的很慢,搜了一圈,暂时没有什么靠谱便宜的解决方案,觉得还是自己来吧.暂时导出到本地用 nginx 查看.
具体的步骤是这样的:

  1. 同步所有文章到本地
  2. 找到 wizNote存放目录,在我电脑上在 /Users/--电脑用户---/.wiznote/---帐号---/data
  3. 用一段 python 代码解决,注意这里面两个位置很重要: index.db 和 notes/*
  4. sqlite 打开 index.db 文件,就能看见所有文档目录结构了.
  5. unzip 所有的 在 sqlite 中的 id标识的文件 到指定的目录里.大致的代码如下里面的账号隐藏掉了:
# -*- coding:UTF-8 -*-
# !/usr/bin/python

import sqlite3
import os
import zipfile

NOTES_PATH = '/Users/--/.wiznote/--/data/notes/'
DATABASE = '/Users/--/.wiznote/--/data/index.db'
EXPORT_BASE = "/Users/--/Downloads/Note"


def dealOne(line):
    file_id = "{" + line[0] + "}"
    filename = line[1]
    dir = EXPORT_BASE + line[2]
    url = line[5]
    ext = line[10]
    create_time = line[12]

    if not os.path.exists(dir):
        print(dir + " does not exist, creating ...")
        os.makedirs(dir)

    if os.path.exists(NOTES_PATH + file_id):
        print(NOTES_PATH + file_id + " exist, unziping ...")
        dir = dir + filename + "/"
        os.makedirs(dir)
        zfile = zipfile.ZipFile(NOTES_PATH + file_id, 'r')
        zfile.extractall(dir)
        zfile.close()


conn = sqlite3.connect(DATABASE)
print("Opened database successfully")
cursor = conn.cursor()
cursor.execute("select * from WIZ_DOCUMENT ")

data = cursor.fetchall()

cursor.close()
conn.close()
for line in data:
    dealOne(line)

  1. 我本地有 MAMP , 直接把解压出来的 Note 目录结构剪切 到 localhost 指向的位置,然后打开 nginx 的目录浏览功能.
    增加 autoindex on; 到 location 配置里
    另外记得加上 charset utf-8; 到 server 配置中,否则中文会有乱码,至此.WizNote 应该就导出到自己的目录里了.
上一篇下一篇

猜你喜欢

热点阅读