不显示Zetero导出的文献库中的部分内容

Zetero作为文献管理软件,收集到的参考文献的相关信息(域fields)比较齐全。文章或书籍的引用中仅仅只用到了其中的一部分,如作者、发表年、题名、期刊(或书籍)等,引用时需要将其他的信息,如doi,url,urldate等域屏蔽掉,或者根据文献的类型,有选择的使用其中的某些域。Zetero通过Javascript脚本控制参考文献的导出,理论上可以修改控制导出的脚本,但是可能比较麻烦,如果在LaTeX文档中使用BibLaTeX宏包,可以控制文献库中的部分内容的显示。

如果希望在所有的manual条目中不显示url域,可以通过如下几种方式:

  1. 全局控制

    \usepackage[
    style=numeric-comp,
    sorting=none,
    doi=false, %不显示doi域
    isbn=false, %不显示isbn域
    url=false, %不显示url域
    eprint=false, %不显示eprint域
    maxnames=99
    ]{biblatex}

    缺陷有2点:

    所有的类型都会屏蔽上述域;

    在online类型中,即使url=false,仍然会显示url域的内容。

  2. 引用时自动清除

    \AtEveryBibitem{%
    \ifentrytype{manual}{%
    }{%
    \clearfield{url}%
    \clearfield{urldate}%
    }%
    }

    如果类型是manual,清除url和urldate中的内容。加强版如下

    %removes url for every type except those listed here
    \AtEveryBibitem{%
    \ifboolexpr{ not (test {\ifentrytype{misc}} or test%
    {\ifentrytype{unpublished}} or test {\ifentrytype{online}}%
    or test {\ifentrytype{inreference}}%
    or test {\ifentrytype{report}}) }%
    {\clearfield{url} \clearfield{urlday} \clearfield{urlmonth} \clearfield{urlyear} }{}
    }
    }

    http://tex.stackexchange.com/questions/65216中也提供了另一个序列控制的方式实现删除。

  3. 通过DeclareFieldFormat命令定义格式

    \DeclareFieldFormat*{url}{}
    \DeclareFieldFormat[manual]{url}{\mkbibacro{URL}\addcolon\space\url{#1}}
    \DeclareFieldFormat*{urldate}{}
    \DeclareFieldFormat[manual]{urldate}{\mkbibparens{\bibstring{urlseen}\space#1}}

    如果类型是manual,重新定义url和urldate的引用格式。

  4. 在JabRef中删除相关条目

    可以批量操作。域名不区分大小写

    选中条目,右键->"set/clear/rename field",最上的Field name是要操作的域(如果选中的条目没 有该域名,则在设置域值时会新建一个域名并填充值),下方有三个选项:set field是设置域值,clear 是删除该域,rename是重命名该域。

    缺点:如果导出的文献包含的域较多,改起来也麻烦!

  5. 使用Better Bib(La)TeX

    安装该扩展后,在preference->Better Bib(La)TeX->import/export中:field to omit from export后输入不需要导出的域。​

    https://retorque.re/zotero-better-bibtex/installation/

  6. 修改导出文件BibTeX.js

    preference->advance->file and folder->Show Data Directory,编辑translator下的 BibTeX.js. 搜索for(var field in fieldMap),添加一行,使得结果为

    for(var field in fieldMap) {
    # only add the following line:
    if (field == "url") continue;
    if(item[fieldMap[field]]) {
    writeField(field, item[fieldMap[field]]);
    }
    }
  7. 导出文献

    选择"better biblatex",字符编码选择"UTF-8"。中文文献在"UTF-8(without BOM)"时,导出的中文乱码

参考文献

  1. https://forums.zotero.org/discussion/39514/delete-fields-for-specific-reference-types-when-exporting-as-bibtex-biblatex/
  2. http://tex.stackexchange.com/questions/52601/url-field-only-for-certain-reference-types-with-biblatex/52603#52603
  3. http://vxlabs.com/2012/06/29/removing-urls-from-zotero-bibtex-exports

有帮助,打赏支持!

不显示Zetero导出的文献库中的部分内容的更多相关文章

  1. Sopus库中FindEigen3.cmake内容详解笔记

    FindEigen3.cmake: # - Try to find Eigen3 lib # Once done this will define # # EIGEN3_FOUND - system ...

  2. TortoiseGit版本库中某个文件显示问号或叹号的问题解决办法

    这是一个怪问题,原因就是文件名大小写与版本库管理的大小写不一致. 解决办法: 1.先把文件夹中的物理文件名改为版本库浏览器中显示的文件名(版本库浏览器中的文件名不知道怎么改),改了以后这个文件图标就变 ...

  3. 获取一个表中的字段总数(mysql) Navicat如何导出Excel格式表结构 获取某个库中的一个表中的所有字段和数据类型

    如何获取一个表中的字段总数 1.function show columns from 表明: 结果 : 2.functiuon select count(*) from INFORMATION_SCH ...

  4. Lib作为“静态库”与“动态库”中的区别

    Lib作为“静态库”与“动态库”中的区别 0. 前言: 什么是静态连接库: 静态库在链接阶段,会将汇编生成的目标文件.o与引用到的库一起链接打包到可执行文件中.因此对应的链接方式称为静态链接. 为什么 ...

  5. 如何导出标准模板库(STL)类的实例化和包含STL类对象数据成员的类

    本文翻译自 https://support.microsoft.com/zh-cn/help/168958/how-to-export-an-instantiation-of-a-standard-t ...

  6. 1.ASP.NET MVC使用EPPlus,导出数据到Excel中

    好久没写博客了,今天特地来更新一下,今天我们要学习的是如何导出数据到Excel文件中,这里我使用的是免费开源的Epplus组件. 源代码下载:https://github.com/caofangshe ...

  7. iOS开发系列--扩展--播放音乐库中的音乐

    众所周知音乐是iOS的重要组成播放,无论是iPod.iTouch.iPhone还是iPad都可以在iTunes购买音乐或添加本地音乐到音乐 库中同步到你的iOS设备.在MediaPlayer.fram ...

  8. 删除本地git版本库中受版本控制的文件

     git乱码解决方案汇总 乱码原因 搜索一番,发现git文件名.log乱码,是普遍问题,这其中有编码的原因,也有跨平台的原因.主要原因是Windows 系统中的Git对中文文件名采用不同的编码保存所致 ...

  9. 【转】c# winform DataGridView导出数据到Excel中,可以导出当前页和全部数据

    准备工作就是可以分页的DataGridView,和两个按钮,一个用来导出当前页数据到Excel,一个用来导出全部数据到Excel 没有使用SaveFileDialog,但却可以弹出保存对话框来 先做导 ...

随机推荐

  1. MySQL truncate()函数的使用说明

    1.TRUNCATE()函数介绍 TRUNCATE(X,D) 是MySQL自带的一个系统函数. 其中,X是数值,D是保留小数的位数. 其作用就是按照小数位数,进行数值截取(此处的截取是按保留位数直接进 ...

  2. 文件上传跨域解决方案-jQuery-File-Upload

    GIT 下载地址 https://github.com/blueimp/jQuery-File-Upload 亲测HTTPS HTTP跨域无压力 不用自带的DEMO 用下面的DEMO <!DOC ...

  3. AutoHome项目的学习

    1.自定义UITabBar #import <UIKit/UIKit.h> @interface XHQTabBarViewController : UITabBarController ...

  4. Python的数据类型与数据结构

    Python的数据类型与数据结构 数据类型分为: 整数型 :数字的整数 浮点型: 数字带小数 字符串: 用 ‘’ 或者 “” 引用的任意文本 布尔型:只有 True 和 False 数据结构分为: 列 ...

  5. 【ABAP系列】ABAP CL_ABAP_CONV_IN_CE

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]ABAP CL_ABAP_CON ...

  6. spring中的BeanFactoryPostProcessor

    spring中的BeanFactoryPostProcessor和BeanPostProcessor有些像,BeanPostProcessor是在bean的初始化前后进行一些操作, BeanFacto ...

  7. 码云、coding拉取项目代码

    1.git init 2.git remote add origin "你的码云或coding项目地址(ssh或https)" 3.git pull origin master

  8. JavaSE基础(七)--Java流程控制语句之switch case 语句

    Java switch case 语句 switch case 语句判断一个变量与一系列值中某个值是否相等,每个值称为一个分支. 语法 switch case 语句语法格式如下: switch(exp ...

  9. poj3107(树的重心,树形dp)

    题目链接:https://vjudge.net/problem/POJ-3107 题意:求树的可能的重心,升序输出. 思路:因为学树形dp之前学过点分治了,而点分治的前提是求树的重心,所以这题就简单水 ...

  10. Connect4 Game

    How this game is playe can be found at here. public class Connect4 { ][]; public Connect4(char[][] b ...