Formulas
Note: a number of functions below talk about the author’s lastname; you can read that as “when available”. If you have the name as a single-field name (for entities like International Business Machines or Aristoteles), Zotero doesn’t have a last name, and the full single-field name is taken instead.
Functions
auth(n=0, m=1, creator='*', initials=false)
The first n (default: all) characters of the mth (default: first) author's last name.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| n | the number of characters to take from the name, 0 = all | 0 | number | 
| m | select the mth author | 1 | number | 
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
| initials | add author initials | false | boolean | 
authAuthEa(creator='*', initials=false, sep='.')
The last name of the first two authors, and ".ea" if there are more than two.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
| initials | add author initials | false | boolean | 
| sep | use this character between authors | '.' | string | 
authEtAl(creator='*', initials=false, sep=' ')
The last name of the first author, and the last name of the
second author if there are two authors or "EtAl" if there are
more than two. This is similar to authEtal2. The difference
is that the authors are not separated by "." and in case of
more than 2 authors "EtAl" instead of ".etal" is appended.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
| initials | add author initials | false | boolean | 
| sep | use this character between authors | ' ' | string | 
authEtal2(creator='*', initials=false, sep='.')
The last name of the first author, and the last name of the second author if there are two authors or ".etal" if there are more than two.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
| initials | add author initials | false | boolean | 
| sep | use this character between authors | '.' | string | 
authForeIni(creator='*')
The given-name initial of the first author.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
authIni(n=0, creator='*', initials=false, sep='.')
The beginning of each author's last name, using no more than n characters (0 = all).
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| n | the number of characters to take from the name, 0 = all | 0 | number | 
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
| initials | add author initials | false | boolean | 
| sep | use this character between authors | '.' | string | 
authorIni(creator='*', initials=false, sep='.')
The first 5 characters of the first author's last name, and the last name initials of the remaining authors.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
| initials | add author initials | false | boolean | 
| sep | use this character between authors | '.' | string | 
authorLast(creator='*', initials=false)
The last name of the last author
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
| initials | add author initials | false | boolean | 
authorLastForeIni(creator='*')
The given-name initial of the last author.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
authorsAlpha(creator='*', initials=false, sep=' ')
Corresponds to the BibTeX style "alpha". One author: First three letters of the last name. Two to four authors: First letters of last names concatenated. More than four authors: First letters of last names of first three authors concatenated. "+" at the end.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
| initials | add author initials | false | boolean | 
| sep | use this character between authors | ' ' | string | 
authorsn(n=0, creator='*', initials=false, sep=' ')
The last names of the first n (default: all) authors.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| n | the number of characters to take from the name, 0 = all | 0 | number | 
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
| initials | add author initials | false | boolean | 
| sep | use this character between authors | ' ' | string | 
authshort(creator='*', initials=false, sep='.')
The last name if one author/editor is given; the first character of up to three authors' last names if more than one author is given. A plus character is added, if there are more than three authors.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| creator | kind of creator to select, *selectsauthorfirst, and if not present,editor,translatororcollaborator, in that order. | '*' | ('author' | 'editor' | 'translator' | 'collaborator' | '*') | 
| initials | add author initials | false | boolean | 
| sep | use this character between authors | '.' | string | 
creatornames(template=?, transliterate=?)
Sets the sprintf-template default for representing creator names. Default is '%(f)s'.
in the creator template, you can use:
- %(f)s: family ("last") name
- %(F)s: family ("last") name without dropping particles
- %(f_zh)s: family ("last") name extracted from chinese compound names. Need- jiebato be enabled
- %(g)s: given ("first") name
- %(g_zh)s: given ("first") name extracted from chinese compound names. Need- jiebato be enabled
- %(i)s: given-name initials
- %(I)s: given-name initials, upper-case
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| template | template string | sprintf-style format template | |
| transliterate | transliterate the returned name | boolean | 
creators(n=0, type=[['primary', 'editor', 'translator', '*']], name='', etal='', sep=' ', min=0, max=0)
Author/editor information.
creator type can be one or more of artist, attorneyAgent, author, bookAuthor, cartographer, castMember, commenter, composer, contributor, cosponsor, counsel, director, editor, guest, interviewee, interviewer, inventor, performer, podcaster, presenter, producer, programmer, recipient, reviewedAuthor, scriptwriter, seriesEditor, sponsor, translator, wordsBy
in the creator template, you can use:
- %(f)s: family ("last") name
- %(F)s: family ("last") name without dropping particles
- %(f_zh)s: family ("last") name extracted from chinese compound names. Need- jiebato be enabled
- %(g)s: given ("first") name
- %(g_zh)s: given ("first") name extracted from chinese compound names. Need- jiebato be enabled
- %(i)s: given-name initials
- %(I)s: given-name initials, upper-case
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| n | select the first ncreators (when passing a number) or the authors in this range (inclusive, when passing two values); negative numbers mean "from the end", default = 0 = all | 0 | (number | [ number, number ]) | 
| type | select only creators of given type(s). Default: all | [['primary', 'editor', 'translator', '*']] | ('' | Creator | Creator[] | (Creator | '')[][]) | 
| name | sprintf-js template. Available named parameters are: f(family name),F(family name without dropping particle),g(given name),i(initials) | '' | ('' | sprintf-style format template) | 
| etal | use this term to replace authors after nauthors have been named | '' | string | 
| sep | use this character between authors | ' ' | string | 
| min | skip to the next pattern if there are less than mincreators, 0 = ignore | 0 | number | 
| max | skip to the next pattern if there are more than maxcreators, 0 = ignore | 0 | number | 
creatortypes(match=?)
This will return a comma-separated list of creator type information for all creators on the item
in the form <1 or 2><creator-type>, where 1 or 2 denotes a 1-part or 2-part creator, and creator-type is one of {{% citekey-formatters/creatortypes %}}, or primary for
the primary creator-type of the Zotero item under consideration. The list is prefixed by the item type, so might look like audioRecording:2performer,2performer,1composer.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| match | Regex to test the creator-type list. When passed, and the creator-type list does not match the regex, jump to the next formule. When it matches, return nothing but stay in the current formule. When no regex is passed, output the creator-type list for the item (mainly useful for debugging). | RegExp | 
date(format='%Y-%m-%d')
The date of the publication
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| format | sprintf-style format template | '%Y-%m-%d' | string | 
extra(variable=?)
A pseudo-field from the extra field. eg if you have Original date: 1970 in your extra field, you can get it as
extra(originalDate), or tex.shortauthor: APA which you could
get with extra('tex.shortauthor'). Any tex. field will be
picked up, the other fields can be selected from this list
of key names.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| variable | extra-field line identifier | none; must be provided | string | 
firstpage
The number of the first page of the publication (Caution: this
will return the lowest number found in the pages field, since
BibTeX allows 7,41,73--97 or 43+.)
group(name=?)
Tests whether the item is in the given group library
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| name | group name | none; must be provided | string | 
infix(format='%(a)s', start=0)
a pseudo-function that sets the citekey disambiguation infix using an sprintf-js format spec
for when a key is generated that already exists. The infix charachter appears at the place of this function of the formula instead of at the and (as postfix does).
You must include exactly one of the placeholders %(n)s (number), %(a)s (alpha, lowercase) or %(A)s (alpha, uppercase).
For the rest of the disambiguator you can use things like padding and extra text as sprintf-js allows. With start set to 1 the disambiguator is always included,
even if there is no need for it when no duplicates exist. The default  format is %(a)s.
in the template, you can use:
- %(a)s: lower-case alphabetic disambiguator
- %(A)s: upper-case alphabetic disambiguator
- %(n)s: numeric disambiguator
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| format | sprintf-style format template | '%(a)s' | sprintf-style format template | 
| start | start value for postfix | 0 | (string | number) | 
inspireHep
Fetches the key from inspire-hep based on DOI or arXiv ID
item(id='key')
returns the internal item ID/key
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| id | 'id': return itemID; 'key': return the item key | 'key' | ('key' | 'id') | 
journal(abbrev='abbrev+auto')
returns the journal abbreviation, or, if not found, the journal title, If 'automatic journal abbreviation' is enabled in the BBT settings,
it will use the same abbreviation filter Zotero uses in the wordprocessor integration. You might want to use the abbr filter on this.
Abbreviation behavior can be specified as abbrev+auto (the default) which uses the explicit journal abbreviation if present, and tries the automatic
abbreviator if not (if auto-abbrev is enabled in the preferences), auto (skip explicit journal abbreviation even if present), abbrev
(no auto-abbrev even if it is enabled in the preferences) or full/off (no abbrevation).
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| abbrev | abbreviation mode | 'abbrev+auto' | ('off' | 'abbrev' | 'auto' | 'abbrev+auto' | 'full') | 
keyword(n=?)
Tag number n. Mostly for legacy compatibility
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| n | position of tag to get | none; must be provided | number | 
language(name=...)
Tests whether the item has the given language set, and skips to the next pattern if not
language can be one or more of ame, american, 'american english', americanenglish, ar, 'ar-ar', 'ar-dz', 'ar-eg', 'ar-iq', 'ar-jo', 'ar-lb', 'ar-ma', 'ar-ps', 'ar-sa', 'ar-sy', 'ar-tn', ara, arabic, 'arabic-algeria', 'arabic-dz', 'arabic-eg', 'arabic-egypt', 'arabic-iq', 'arabic-iraq', 'arabic-jo', 'arabic-jordan', 'arabic-lb', 'arabic-lebanon', 'arabic-ma', 'arabic-morocco', 'arabic-palestinianterritories', 'arabic-ps', 'arabic-sa', 'arabic-saudiarabia', 'arabic-sy', 'arabic-syria', 'arabic-tn', 'arabic-tunisia', australian, 'australian english', australianenglish, austrian, 'austrian german', 'austrian-traditional', austriangerman, 'austriangerman-traditional', bri, british, 'british english', britishenglish, canadian, 'canadian english', canadianenglish, chinese, 'chinese-hans', 'chinese-hans-hk', 'chinese-hans-mo', 'chinese-hans-sg', 'chinese-hant', 'chinese-hant-hk', 'chinese-hant-mo', 'chinese-simplified', 'chinese-simplified-hongkongsarchina', 'chinese-simplified-macausarchina', 'chinese-simplified-singapore', 'chinese-traditional', 'chinese-traditional-hongkongsarchina', 'chinese-traditional-macausarchina', de, 'de-1901', 'de-1996', 'de-at', 'de-at-1901', 'de-at-1996', 'de-ch', 'de-ch-1901', 'de-ch-1996', 'de-de', deutsch, en, 'en-au', 'en-ca', 'en-en', 'en-gb', 'en-nz', 'en-us', eng, english, 'english-au', 'english-australia', 'english-ca', 'english-canada', 'english-gb', 'english-newzealand', 'english-nz', 'english-unitedkingdom', 'english-unitedstates', 'english-us', ger, german, 'german-at', 'german-at-traditional', 'german-austria', 'german-austria-traditional', 'german-ch', 'german-ch-traditional', 'german-switzerland', 'german-switzerland-traditional', 'german-traditional', ja, 'ja-ja', jap, japanese, nau, naustrian, newzealand, nge, ngerman, nsw, nswissgerman, 'schweizer hochdeutsch', 'simplified chinese', 'swiss high german', swisshighgerman, 'swisshighgerman-traditional', 'traditional chinese', tw, ukenglish, usenglish, zh, 'zh-hans', 'zh-hans-hk', 'zh-hans-mo', 'zh-hans-sg', 'zh-hant', 'zh-hant-hk', 'zh-hant-mo', 'zh-tw', 'zh-zh', '?sterreichisches deutsch', '???????', '中文', '中文-中文', '日本語', '簡體中文', '繁體中文'
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| name | one or more language codes | none; must be provided | string[] | 
lastpage
The number of the last page of the publication (See the remark on firstpage)
library
Tests whether the item is in the user library
month
the month of the publication
origdate
the original date of the publication
origyear
the original year of the publication
postfix(format='%(a)s', start=0)
a pseudo-function that sets the citekey disambiguation postfix using an sprintf-js format spec
for when a key is generated that already exists. Does not add any text to the citekey otherwise.
You must include exactly one of the placeholders %(n)s (number), %(a)s (alpha, lowercase) or %(A)s (alpha, uppercase).
For the rest of the disambiguator you can use things like padding and extra text as sprintf-js allows. With start set to 1 the disambiguator is always included,
even if there is no need for it when no duplicates exist. The default  format is %(a)s.
in the template, you can use:
- %(a)s: lower-case alphabetic disambiguator
- %(A)s: upper-case alphabetic disambiguator
- %(n)s: numeric disambiguator
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| format | sprintf-style format template | '%(a)s' | sprintf-style format template | 
| start | start value for postfix | 0 | (string | number) | 
shorttitle(n=3, m=0)
The first n (default: 3) words of the title, apply capitalization to first m (default: 0) of those.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| n | number of words to select | 3 | number | 
| m | number of words to capitalize. 0means no words will be capitalized. Mind that existing capitals are not removed. If you enable capitalization, you also get transliteration; for CJK, capitalization is not meaningful, so if you want capitalization, BBT romanizes first. | 0 | number | 
shortyear
The last 2 digits of the publication year
title
Capitalize all the significant words of the title, and concatenate them. For example, An awesome paper on JabRef will become AnAwesomePaperJabref
transliterate(mode=?)
Set the default transliteration mode. If you don't specify a mode, the mode for an entry is derived from the item language field
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| mode | specialized translateration modes for german, japanese or chinese. | none; must be provided | (('minimal' | 'german' | 'japanese' | 'chinese' | 'arabic' | 'ukranian' | 'mongolian' | 'russian') | 'de' | 'ja' | 'chinese-traditional' | 'zh-hant' | 'zh' | 'tw' | 'ar' | 'uk' | 'mn' | 'ru') | 
type(allowed=...)
Without arguments, returns the item type.
When arguments as passed, tests whether the item is of any of the given types, and skips to the next pattern if not, eg type(book) + veryshorttitle | auth + year.
creator type can be one or more of annotation, artwork, attachment, audioRecording, bill, blogPost, book, bookSection, case, computerProgram, conferencePaper, dataset, dictionaryEntry, document, email, encyclopediaArticle, film, forumPost, hearing, instantMessage, interview, journalArticle, letter, magazineArticle, manuscript, map, newspaperArticle, note, patent, podcast, preprint, presentation, radioBroadcast, report, standard, statute, thesis, tvBroadcast, videoRecording, webpage
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| allowed | one or more item type names | none; must be provided | string[] | 
veryshorttitle(n=1, m=0)
The first n words of the title, apply capitalization to first m of those
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| n | number of words to select | 1 | number | 
| m | number of words to capitalize. 0means no words will be capitalized. Mind that existing capitals are not removed. | 0 | number | 
year
The year of the publication
zotero
Generates citation keys as the stock Zotero Bib(La)TeX export does. Note that this pattern inherits all the problems of the original Zotero citekey generation -- you should really only use this if you have existing papers that rely on this behavior.
Note: All auth... functions will fall back to editors if no authors are present on the item.
Note: The functions above used to have the clean function automatically applied to them, this is no longer the case, so if you have CJK authors/titles and you want to manipulate them (using eg. capitalize), you could have to use transliterate on them first, eg. authEtal2.transliterate.capitalize + year + shorttitle(3, 3).
Direct access to unprocessed fields (“Field functions”)
The above functions all retrieve information stored in the item’s fields and process it in some way. If you don’t want this, you can instead call field contents without any processing. To access Zotero fields, refer to them as given in the table below:
| AbstractNote | AccessDate | AdminFlagJM | AdoptionDateJM | 
| AlbumJM | ApplicationNumber | Archive | ArchiveCollectionJM | 
| ArchiveIDZ | ArchiveLocation | ArtworkMedium | ArtworkSize | 
| AssemblyNumberJM | Assignee | AudioFileType | AudioRecordingFormat | 
| AuthorityZ | BillNumber | BlogTitle | BookAbbreviationJM | 
| BookTitle | CallNumber | CaseName | Code | 
| CodeNumber | CodePages | CodeVolume | Committee | 
| Company | ConferenceDateJM | ConferenceName | Country | 
| Court | DOI | Date | DateAmendedJM | 
| DateDecided | DateEnacted | DictionaryTitle | Distributor | 
| DivisionJM | DocketNumber | DocumentNameJM | DocumentNumber | 
| Edition | EncyclopediaTitle | EpisodeNumber | FilingDate | 
| FirstPage | FormatZ | ForumTitle | GazetteFlagJM | 
| Genre | History | ISBN | ISSN | 
| IdentifierZ | Institution | InterviewMedium | Issue | 
| IssueDate | IssuingAuthority | JournalAbbreviation | JurisdictionJM | 
| Label | Language | LegalStatus | LegislativeBody | 
| LetterType | LibraryCatalog | ManuscriptType | MapType | 
| Medium | MeetingName | MeetingNumberJM | NameOfAct | 
| Network | NewsCaseDateJM | NumPages | Number | 
| NumberOfVolumes | OpeningDateJM | OpusJM | OrganizationZ | 
| OriginalDateJM | Pages | ParentTreatyJM | PatentNumber | 
| Place | PostType | PresentationType | PriorityDateJM | 
| PriorityNumbers | ProceedingsTitle | ProgramTitle | ProgrammingLanguage | 
| PublicLawNumber | PublicationDateJM | PublicationNumberJM | PublicationTitle | 
| Publisher | References | RegnalYearJM | RegulationTypeJM | 
| RegulatoryBodyJM | ReignJM | ReleaseJM | ReportNumber | 
| ReportType | Reporter | ReporterVolume | RepositoryZ | 
| RepositoryLocationZ | ResolutionLabelJM | Rights | RunningTime | 
| Scale | Section | Series | SeriesNumber | 
| SeriesText | SeriesTitle | Session | SessionTypeJM | 
| ShortTitle | SigningDateJM | Status | Studio | 
| Subject | SupplementNameJM | System | ThesisType | 
| Title | TreatyNumberJM | Type | University | 
| Url | VersionNumber | VideoRecordingFormat | Volume | 
| VolumeTitleJM | WebsiteTitle | WebsiteType | YearAsVolumeJM | 
(fields marked Z are only available in Zotero, fields marked with JM are only available in Juris-M).
Filters
abbr(chars=1)
Abbreviates the text. Only the first character and subsequent characters following white space will be included.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| chars | number of characters to return per word | 1 | number | 
acronym(list='acronyms', reload=false, passthrough=false)
Does an acronym lookup for the text.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| list | lookup list. The list must be a CSV file and live in the Zotero/better-bibtexdirectory in your Zotero profile, and must use commas as the delimiter. | 'acronyms' | string | 
| reload | reload the list for every call. When off, the list will only be read at startup of Better BibTeX. You can set this to true temporarily to live-reload a list. | false | boolean | 
| passthrough | if no match is found, pass through input. | false | boolean | 
alphanum
clears out everything but unicode alphanumeric characters (unicode character classes L and N)
ascii
removes all non-ascii characters
capitalize
uppercases the first letter of each word
clean
transliterates the citation key and removes unsafe characters
condense(sep='')
replaces spaces in the value passed in. You can specify what to replace it with by adding it as a
parameter, e.g .condense('_') will replace spaces with underscores. Equivalent to .replace(/\s+/g, sep).
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| sep | replacement character | '' | string | 
default(text=?)
Returns the given text if no output was generated
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| text | literal text to return | none; must be provided | string | 
discard
discards the input
find(match=?, passthrough=false)
Finds a text in the string and returns it.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| match | regex or string to match. String matches are case-insensitive | none; must be provided | (string | RegExp) | 
| passthrough | if no match is found, pass through input. | false | boolean | 
formatDate(format='%Y-%m-%d')
formats date as by replacing y, m and d in the format
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| format | sprintf-style format template | '%Y-%m-%d' | string | 
ideographs
Treat ideaographs as individual words
jieba
word segmentation for Chinese items. Uses substantial memory, and adds about 7 seconds to BBTs startup time; must be enabled under Preferences -> Better BibTeX -> Advanced -> Citekeys
kuromoji
word segmentation for Japanese items. Uses substantial memory; must be enabled under Preferences -> Better BibTeX -> Advanced -> Citekeys
len(relation='>', length=0)
If the length of the output does not match the given number, skip to the next pattern.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| relation | comparison operator | '>' | ('<' | '>' | '<=' | '==' | '!=' | '>=') | 
| length | value to compare length with | 0 | number | 
localTime
transforms date/time to local time. Mainly useful for dateAdded and dateModified as it requires an ISO-formatted input.
lower
Forces the text inserted by the field marker to be in lowercase. For example, auth.lower expands to the last name of the first author in lowercase.
match(match=?, clean=false)
If the output does not match the given string/regex, skip to the next pattern.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| match | regex or string to match. String matches are case-insensitive | none; must be provided | (string | RegExp) | 
| clean | transliterates the current output and removes unsafe characters during matching | false | boolean | 
nopunct(dash='-')
Removes punctuation
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| dash | replace dashes with given character | '-' | string | 
nopunctordash
Removes punctuation and word-connecting dashes. alias for nopunct(dash='')
numeric
returns the value if it's an integer
pinyin
transliterates the citation key to pinyin
postfix(postfix=?)
postfixes with its parameter, so postfix('_') will add an underscore to the end if, and only if, the value
it is supposed to postfix isn't empty
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| postfix | postfix string | none; must be provided | string | 
prefix(prefix=?)
prefixes with its parameter, so .prefix('_') will add an underscore to the front if, and only if, the value
it is supposed to prefix isn't empty.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| prefix | prefix string | none; must be provided | string | 
replace(find=?, replace=?)
replaces text, for the text to match you can pass either:
- a string: .replace('.etal','&etal')which will match case-insensitive, so will replace.EtAlwith&etal.
- javascript regular expression: .replace(/[.]etal/ig, '&etal')
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| find | string or regex to match. String matches are case-insensitive | none; must be provided | (string | RegExp) | 
| replace | literal text to replace the match with | none; must be provided | string | 
select(start=1, n=?)
selects words from the value passed in. The format is select(start,number) (1-based), so select(1,4) or select(n=4)
would select the first four words. If n is not given, all words from start to the end are
selected.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| start | first word to select (1-based) | 1 | number | 
| n | number of words to select. Default is all. | number | 
skipwords(nopunct=false)
filters out common words like 'of', 'the', … the list of words can be seen and changed by going into
about:config under the key extensions.zotero.translators.better-bibtex.skipWords as a comma-separated,
case-insensitive list of words.
If you want to strip words like 'Jr.' from names, you could use something like Auth.nopunct.skipwords.fold
after adding jr to the skipWords list.
Note that this filter is always applied with nopunct on if you use title (which is different from Title) or shorttitle.
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| nopunct | remove punctuation from words | false | boolean | 
substring(start=1, n=?)
substring(start,n) selects n (default: all) characters starting at start
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| start | starting character (counting from 1) | 1 | number | 
| n | number of characters to select (default: remainder from start) | number | 
transliterate(mode=?)
transliterates the citation key. If you don't specify a mode, the mode is derived from the item language field
| parameter | value assumed when not provided | valid values | |
|---|---|---|---|
| mode | specialized translateration modes for german, japanese or chinese. | (('minimal' | 'german' | 'japanese' | 'chinese' | 'arabic' | 'ukranian' | 'mongolian' | 'russian') | 'de' | 'ja' | 'chinese-traditional' | 'zh-hant' | 'zh' | 'tw' | 'ar' | 'uk' | 'mn' | 'ru') | 
upper
Forces the text inserted by the field marker to be in uppercase. For example, auth.upper expands the last name of the first author in uppercase.
Usage note: the functions condense, skipwords, capitalize and select rely on whitespaces for word handling. Most functions strip
whitespace and thereby make these filter functions sort of useless. You will in general want to use the fields from the
table above, which give you the values from Zotero without any changes. The fields with ** are only available in Juris-M.