同义词 / 别名的一个小建议

本贴最后更新于 1511 天前,其中的信息可能已经时移世改

在记笔记的时候我们应该都很经常遇到同义词的现象,比如一个人的名字有中文的不同翻译 + 英文名,一个名词、定理的全称和简称等等。我很希望可以在日后搜索时无论搜索哪一个关键词都可以找到这个块,而不是每次写的时候都提心吊胆的不能用英文名或是不能用简称。

思源很明显已经考虑到了这个问题,并且给出了别名这个解决方案。但是怎么说呢,就感觉很不方便,我只能一个块一个块的去添加别名,这就是一个很大的工作量,然后可能还会有遗漏,我希望有一个一劳永逸的解决方案,目前有两种简单的想法:

  1. 现在已经有别名机制了,或许就可以利用他进行稍微拓展一些的开发。我们事先在软件中进行设置同义词,比如我设定麦克斯韦方程组、Maxwell Equation、Maxwell Eq 是同义词,然后呢在我每编辑完一个标题、块的时候就进行一下扫描,无论发现哪个关键词都自动添加其他的两个别名;然后以后再次修改时在重新扫描一次。
  2. 还是事先设置同义词,直接在引用时检测如果发现这些关键词就自动搜索含这些同义词的块。仍采用上面的那个例子,我输入“【【麦克斯韦方程组”,软件检测一下,发现了有同义词,就把搜索逻辑改成含“麦克斯韦方程组”或“Maxwell Equation”或“Maxwell Eq”。当然如果输入“【【麦克斯韦”(即输入某个同义词的前几个字)也能匹配就更好了。但是这样可能会造成较多的误搜索结果,不过影响可能不大?因为我使用的时候误搜索结果也不少,尤其搜数字(我闲着没事测试用的,好像正常情况搜数字比较少,除非搜日期之类,或许可以考虑优化一下这方面,就是图片、块的 id 啥的排除在搜索结果外),影响也不大。具体利弊就请 D 大、V 姐权衡了。
  • 思源笔记

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

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

    25523 引用 • 105573 回帖 • 1 关注

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 非常感谢你的建议

    1. 自动添加可能会添加一些不想要的东西上来,一个段落可能会同时命中多组同义词。
    2. 可以使用 SQL 进行插叙,麻烦的话可以把 SQL 设置为一个模版。
    2 回复
  • ri 1 赞同

    对于这个,我觉得可以参考一下 RoamEdit 的解决方案,创立一个特殊的文件,专门用于存放同义词

    鲁迅周树人

    并且在搜索的时候留出一行同义词

  • zhangy 1 评论
    作者

    V 姐,您说的第一条没特别理解。是说一个段落可能既有鲁迅、又有麦克斯韦吗,这样的话同时加上分别的同义词不应该正是我们比较需要的一个情况吗,就是后续搜索搜周树人/Maxwell 都能找到这个段落。我觉得可能有问题的情况可能是一个段落既有鲁迅又有周树人,对这种情况我觉得可以一组同义词只要扫描到一次就把其他的词加上去,然后这一组同义词暂时失效这样一个逻辑。

    因为我对同义词的这个定义基本是无论在什么情况下,或者说 99% 的情况下这俩词的意思都是完全一样的,所以我认为加上不想要的东西基本不太可能,基本没有什么情况我需要把鲁迅和周树人区分开,也不需要把 md 和 markdown 区分开,这在几乎所有情况下都是一个意思完全相同的事情,但是我在写文章时确实会时不时乱用,一会写个 md,一会写个 markdown。只要不滥用这个功能进行。而且由于这个功能需要事先预设,滥用的概率也很低。

    如果比较影响性能,或许可以在刷新文件树的时候同时进行一次?

    然后 V 姐提到的解决方案好像确实可以,我研究一下模板的使用,还没太研究过这一块。感谢 V 姐。

    我的意思是自动可能会产生大量的别名。随着同义词的增加,每个块上都会有非常多的别名,这可能不是我们所想要的。
    Vanessa
  • Dawn99 5 评论

    是的,感觉第一个方案会使得块增加没必要的同义词,这个主要是很多包含这个词语的块并不一定就要表达这个词语的意思。

    感觉使用同义词更多的还是在搜索的时候。大家都比较希望能在搜索“麦克斯韦方程组”的时候也能照顾到“Maxwell Equations”。这个或许创建一个同义词的文件(或者是设置项),能在搜索其中其中词语的时候同时搜索同义词,或许会比较契合楼主的意思?

    当然现在也有解决方法。就是创建一些包含同义词的 sql 模板,但是这个方法在搜索框就没法用上了。。。

    搜索框也可以使用 sql
    Vanessa
    @Vanessa 噢,是的,我的意思是没法使用模板,得自己输入所有的同义词
    Dawn99
    @Dawn99 好的,你说服我了,已记录,但是优先级不高,感谢
    Vanessa 1
    @Vanessa 嗯嗯,感谢感谢,这种有替代方案的不急
    Dawn99
    @Dawn99 理解万岁
    Vanessa

推荐标签 标签

  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    125 引用 • 585 回帖
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    22 引用 • 148 回帖 • 17 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 316 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    133 引用 • 1124 回帖 • 109 关注
  • 电影

    这是一个不能说的秘密。

    122 引用 • 608 回帖
  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    2 引用 • 14 回帖 • 6 关注
  • 国际化

    i18n(其来源是英文单词 internationalization 的首末字符 i 和 n,18 为中间的字符数)是“国际化”的简称。对程序来说,国际化是指在不修改代码的情况下,能根据不同语言及地区显示相应的界面。

    8 引用 • 26 回帖 • 4 关注
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 233 回帖
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    24 引用 • 241 回帖
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    20 引用 • 23 回帖 • 740 关注
  • NGINX

    NGINX 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 NGINX 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本 0.1.0 发布于 2004 年 10 月 4 日。

    315 引用 • 547 回帖 • 1 关注
  • 思源笔记

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

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

    25523 引用 • 105573 回帖 • 1 关注
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    21 引用 • 245 回帖 • 227 关注
  • 程序员

    程序员是从事程序开发、程序维护的专业人员。

    589 引用 • 3538 回帖
  • 持续集成

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

    15 引用 • 7 回帖 • 2 关注
  • 倾城之链
    23 引用 • 66 回帖 • 167 关注
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    9766 引用 • 44433 回帖 • 88 关注
  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    195 引用 • 291 回帖 • 373 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 17 关注
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    54 引用 • 44 回帖 • 1 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 487 关注
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 91 关注
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    91 引用 • 59 回帖 • 2 关注
  • 叶归
    8 引用 • 38 回帖 • 18 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 636 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    7 引用 • 30 回帖 • 386 关注