windows本地使用tiddlywiki的一种方案

tiddlywiki是一款优秀轻便的个人wiki。

一种使用方法

  • 单独使用一个浏览器主要用于书写wiki,设置默认下载路径为wiki的存放路径。

  • 将wiki直接保存为一个浏览器书签。

  • 解决保存后,将最新内容版更新为原始wiki名称(书签保存的wiki名称),并备份

    浏览器下载后,最新的文件会被重命名为xxx(1).html, xxx(2).html,..., xxx(n).html

    • 通过一个python脚本实现,创建windows后台任务,每隔数分钟执行一次
    • 创建windows执行python的定时任务
    • 自动将最新文件(最新一次浏览器重命名的文件)重命名为原始文件名,并进行备份的脚本
import os
import re
import time
import shutil
import logging
from operator import itemgetter
from pathlib import Path

class Logger:
    def __init__(self, file, dir, level=logging.DEBUG):
        self.logger = logging.getLogger()
        self.logger.setLevel(logging.INFO)
        fmt = logging.Formatter('[%(asctime)s][%(levelname)s] %(message)s', '%Y-%m-%d %H:%M:%S')
        # 设置CMD日志
        sh = logging.StreamHandler()
        sh.setFormatter(fmt)
        sh.setLevel(level)
        # 设置文件日志
        log_path = os.path.join(dir,'log')
        if os.path.exists(log_path):
            shutil.rmtree(log_path)
        os.mkdir(log_path)
        fh = logging.FileHandler(os.path.join(log_path, file))
        fh.setFormatter(fmt)
        fh.setLevel(level)

        self.logger.addHandler(sh)
        self.logger.addHandler(fh)

    def info(self, message):
        self.logger.info(message)

    def warn(self, message):
        self.logger.warn(message)

    def error(self, message):
        self.logger.error(message)

class CurDirFileOp:
    def __init__(self, rootDir, suffix):
        self.allFile = self.listAllFiles(rootDir)
        self.suffixFile = self.getSuffixFile(self.allFile, suffix)

    def listAllFiles(self, rootDir):
        _files = []
        list = os.listdir(rootDir)  # 列出文件夹下所有的目录与文件
        for i in range(0, len(list)):
            path = os.path.join(rootDir, list[i])
            if os.path.isdir(path):
                _files.extend(self.listAllFiles(path))
            if os.path.isfile(path):
                _files.append(path)
        return _files

    def getSuffixFile(self, allFile, suffix):
        _files = []
        lenth = len(suffix)
        if lenth is 0:
            return _files
        for file in allFile:
            if file[-lenth:] != suffix or os.path.isdir(file):
                continue  # 过滤非目标文件
            _files.append(file)
        return _files

    def getSonDir(self, rootDir, sonDirName):
        path = os.path.join(rootDir, sonDirName)
        if os.path.exists(path) is False:
            os.makedirs(path)
        return path

    def genNewFileName(self, fileNameIn, addStr):
        '''
        在后缀前添加字符串为新文件名
        '''
        nameList = re.split(r'([.])', fileNameIn)
        newName = nameList[0] + '-' + str(addStr) + str(nameList[1]) + str(nameList[2])
        return newName

class WikiOp:
    def __init__(self):
        self.wikiDir = os.path.abspath('.')
        self.fo = CurDirFileOp(self.wikiDir, 'html')
        self.htmlFile = self.fo.suffixFile
        self.backDir = self.fo.getSonDir(self.wikiDir, 'back')
        self.locTime = time.strftime("%Y_%m_%d_%H_%M_%S", time.localtime())

    def getWikiFile(self):
        '''
        'D:\\working\\tools\\cornfield\\tiddlywiki\\123': 
            [
                {'index': 0, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\123.html'}
            ],
        'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki': 
            [
                {'index': 10, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki(10).html'}, 
                {'index': 2, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki(2).html'}, 
                {'index': 3, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki(3).html'}, 
                {'index': 4, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki(4).html'}, 
                {'index': 5, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki(5).html'}, 
                {'index': 6, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki(6).html'}, 
                {'index': 7, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki(7).html'}, 
                {'index': 8, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki(8).html'}, 
                {'index': 9, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki(9).html'}, 
                {'index': 0, 'fileName': 'D:\\working\\tools\\cornfield\\tiddlywiki\\mywiki.html'}
            ]
        }
        '''
        allWikiDic = {}
        for file in self.htmlFile:
            if self.backDir in file:
                continue
            fileName = re.split(r'([().])', file)
            if len(fileName) is 7:
                index = int(fileName[2])
            elif len(fileName) is 3:
                index = 0
            else:
                continue
            itemKey = fileName[0]
            singleDict = {}
            singleDict["index"] = index
            singleDict['fileName'] = file
            if itemKey not in allWikiDic:
                allWikiDic[itemKey] = []

            allWikiDic[itemKey].append(singleDict)

        return allWikiDic

    def delBracketsOfBrowserRename(self, fileNameIn):
        nameList = re.split(r'[()]', fileNameIn)
        newName = nameList[0] + nameList[-1]
        return newName

    def backOldAndRnameNewWiki(self):
        wikiDic = self.getWikiFile()
        for item in wikiDic:
            allFile = self.fo.listAllFiles(self.wikiDir)
            wikiList = wikiDic[item]
            wikiList = sorted(wikiList,key = itemgetter('index'),reverse = True)
            if len(wikiList) is 1:
                if  wikiList[0]['fileName'].find("(") is -1:  # 跳过 不需要修改的
                    continue

            for idx in range(1, len(wikiList)): # backUp
                fileName = wikiList[idx]['fileName']
                newName = self.fo.genNewFileName(fileName, self.locTime)
                log.info("%s rename to: %s" %(fileName, newName))
                os.rename(fileName, newName)
                log.info("%s move to: %s" %(newName, self.backDir))
                shutil.move(newName, self.backDir)
            if len(wikiList) is not 0:
                fileName = wikiList[0]['fileName']
                newName = self.delBracketsOfBrowserRename(fileName)
                log.info("%s rename to: %s" %(fileName, newName))
                os.rename(fileName, newName)

if __name__ == "__main__":
    global dirHome, log
    dirHome = os.path.split(os.path.realpath(__file__))[0]
    os.chdir(dirHome)
    log = Logger('wikiback.log', dirHome, logging.INFO)
    wiki = WikiOp()
    wiki.backOldAndRnameNewWiki()
    log.info("-------------------------------back and rename ok!--------------------------------")
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容