一键获取当前块、文档和笔记本信息

本贴最后更新于 566 天前,其中的信息可能已经东海扬尘

Image with no description

获取当前块、文档和笔记本信息 - 动作信息 - Quicker (getquicker.net)

import json
import requests
import os
from jsonpath_ng.ext import parse
import sys


class SiYunNoteBook:
    def __init__(self, TokenID) -> None:
        self.TokenID = TokenID

    def Command(self, url: str, data=None, indent=False):
        headers = {
            "Content-Type": "application/javascript",
            "Authorization": f"Token { self.TokenID }"
        }
        Result = requests.post(f"http://localhost:6806{ url }",
                               headers=headers, data=json.dumps(data))
        if indent:
            return (json.dumps(json.loads(Result.text), indent=True, ensure_ascii=False))
        else:
            return json.loads(Result.text)

    def lsNotebooks(self) -> str:
        return self.Command("/api/notebook/lsNotebooks")

    def openNotebook(self, nbID: str):
        return self.Command("/api/notebook/openNotebook", data={"notebook": nbID})

    def closeNotebook(self, nbID: str):
        return self.Command("/api/notebook/closeNotebook", data={"notebook": nbID})

    def renameNotebook(self, nbID: str, newName: str):
        return self.Command("/api/notebook/renameNotebook", data={"notebook": nbID, "name": newName})

    def createNotebook(self, nb_name: str):
        return self.Command("/api/notebook/createNotebook", data={"name": nb_name})

    def removeNotebook(self, nbID: str):
        return self.Command("/api/notebook/removeNotebook", data={"notebook": nbID})

    def getNotebookConf(self, nbID: str, dict: dict):
        return self.Command("/api/notebook/getNotebookConf", data={"notebook": nbID, "conf": dict})

    def setNotebookConf(self, nbID):
        return self.Command("/api/notebook/setNotebookConf", data={"notebook": nbID})

    def createDocWithMd(self, nbID: str, path: str, markdown: str):
        return self.Command("/api/filetree/createDocWithMd",
                            data={"notebook": nbID,
                                  "path": path,
                                  "markdown": markdown
                                  })

    def appendBlock(self, parentID: str, data: str):
        return self.Command("/api/block/appendBlock",
                            data={"data": data,
                                  "dataType": "markdown",
                                  "parentID": parentID
                                  })

    def prependBlock(self, parentID: str, dataType: str, data):
        return self.Command("/api/block/prependBlock",
                            data={"data": data,
                                  "dataType": "markdown",
                                  "parentID": parentID
                                  })

    def insertBlock(self, previousID: str, data: str):
        return self.Command("/api/block/prependBlock",
                            data={
                                "dataType": "markdown",
                                "data": data,
                                "parentID": previousID
                            })

    def pushMsg(self, Msg: str):
        return self.Command("/api/notification/pushMsg",
                            data={"msg": Msg, "timeout": 7000}
                            )

    def pushErrMsg(self, Msg: str):
        return self.Command("/api/notification/pushErrMsg",
                            data={"msg": Msg, "timeout": 7000}
                            )

    def version(self):
        return self.Command("/api/system/version",
                            data={}
                            )

    def exportMdContent(self, doc_id: str):
        return self.Command("/api/export/exportMdContent",
                            data={"id": doc_id}
                            )

    def getFileContent(self, file: str):
        return self.Command("/api/file/getFile",
                            data={"path": file}
                            )

    def render(self, doc_id: str, template_path: str):
        return self.Command("/api/file/render",
                            data={"id": doc_id,
                                  "path": template_path
                                  }
                            )

    def SQL_query(self, SQL: str):
        return self.Command("/api/query/sql",
                            data={"stmt": SQL})

    def getBlockAttrs(self, block_id: str):
        return self.Command("/api/attr/getBlockAttrs",
                            data={"id": block_id})

    def setBlockAttrs(self, block_id: str, dict: dict):
        return self.Command("/api/attr/setBlockAttrs",
                            data={"id": block_id,
                                  "attrs": dict
                                  })

    def getBlockKramdown(self, block_id: str):
        return self.Command("/api/block/getBlockKramdown",
                            data={"id": block_id})

    def deleteBlock(self, block_id: str):
        return self.Command("/api/block/deleteBlock",
                            data={"id": block_id})

    def updateBlock(self, doc_id: str, dataType: str, data):
        return self.Command("/api/block/updateBlock",
                            data={"id": doc_id,
                                  "dataType": dataType,
                                  "data": data
                                  }
                            )

    def getDocumentIDbyBlock(self, block_id):
        result = self.SQL_query(
            f"SELECT root_id FROM blocks where id= '{ block_id }'")
        return (result["data"][0]["root_id"])

    def upload(self, imageFile):
        headers = {
            "Authorization": f"Token { self.TokenID }"
        }
        values = {"assetsDirPath": "/assets/"}
        fields = {
            "file[]": ('file.png', open(imageFile, 'rb'), 'jpeg/png')
        }
        Result = requests.post("http://localhost:6806/api/asset/upload",
                               headers=headers,  files=fields, data=values)
        return (json.loads(Result.text))

    def getConf_Siyuan(self):
        return self.Command("/api/system/getConf",  data={})


TokenID: str = "{API_token}"
block_id: str = "{block_id}"
SY = SiYunNoteBook("SiYunNoteBook")
INFO = SY.SQL_query(
    f'SELECT box,root_id,hpath, path FROM blocks where id= "{block_id}"')
NB_id: str = INFO["data"][0]["box"]
doc_id: str = INFO["data"][0]["root_id"]
hpath: str = INFO["data"][0]["hpath"]
title: str = os.path.basename(hpath) if hpath else ""
Result = SY.getConf_Siyuan()
dataDir: str = Result["data"]["conf"]["system"]["dataDir"]
filePath: str = f'{dataDir}\\{NB_id}{INFO["data"][0]["path"]}'.replace(
    "/", "\\")

INFO: str = {
	"当前块ID": block_id,
    "当前笔记本ID": NB_id,
    "当前文档ID": doc_id,  
    "当前文档标题": title,
    "文档逻辑路径": hpath,
    "文档物理路径": filePath  
}

print(json.dumps(INFO, indent=2, ensure_ascii=False))
  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    22353 引用 • 89444 回帖
1 操作
ttChen 在 2023-05-05 23:41:52 更新了该帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    342 引用 • 708 回帖
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖 • 4 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3453 回帖 • 203 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 680 关注
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 94 关注
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    21 引用 • 31 回帖 • 1 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    5 引用 • 7 回帖
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    32 引用 • 131 回帖 • 1 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 64 关注
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 73 关注
  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 462 关注
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖 • 4 关注
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    286 引用 • 248 回帖 • 61 关注
  • 反馈

    Communication channel for makers and users.

    123 引用 • 911 回帖 • 245 关注
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    62 引用 • 289 回帖 • 1 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 49 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 30 关注
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 764 关注
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 355 关注
  • GraphQL

    GraphQL 是一个用于 API 的查询语言,是一个使用基于类型系统来执行查询的服务端运行时(类型系统由你的数据定义)。GraphQL 并没有和任何特定数据库或者存储引擎绑定,而是依靠你现有的代码和数据支撑。

    4 引用 • 3 回帖 • 9 关注
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 638 关注
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖 • 1 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1348 回帖
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖 • 1 关注
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    36 引用 • 35 回帖 • 1 关注
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    17 引用 • 236 回帖 • 328 关注