Suppose I've just made the switch to biblatex
. I have chosen one of the built-in styles (numeric
, alphabetic
, authoryear
, authortitle
, verbose
) or of the custom styles available at CTAN, and I've figured out how to sort/compress citations. The bibliography and the in-text-citations look approximately like I want, but need to be tweaked. I've taken a look at the biblatex
documentation for advice, but it is somewhat daunting. How do I get started? To add some focus, customization in the following areas would come in handy:
-
Suppressing of specific BibTeX fields (e.g.,
publisher
); -
Formatting of fields for specific entry types (e.g., titles of articles not inside quotation marks);
-
Formatting of citation postnotes (i.e., getting rid of "p."/"pp.");
-
Spacing and punctuation in the bibliography (e.g., commas instead of periods as unit separators);
-
Order of first names and last names of authors/editors in the bibliography;
-
Order of certain fields in the bibliography (e.g., swapping
location
andpublisher
); -
Language-specific terms (e.g., replacing "References" with "Works Cited").
Finally, assuming that I'll want to use my style adjustments in a multitude of documents: Where do I put the relevant macro stuff?
Best Answer
I'll start with a few words of caution. First, while most of the following tips should also be applicable for custom CTAN styles, my focus is on the standard styles that ship with
biblatex
. Second, these guidelines are about easy-to-medium modifications; for the trickier stuff look at some of the other questions at TeX.sx (or ask your own one).Introduction
As newer versions of
biblatex
were released, customizations that formerly required redefining internal macros (or at least changing settings mid-document) have become package options settable in the preamble. Here's how to do some often-requested tweaks:giveninits=true
will render all first and middle names as initials. (Introduced in v0.8, renamed in v3.3, is calledfirstinits
in pre-3.3 versions)isbn=false
will suppress anyisbn
fields included in your.bib
file. (It works the same way forurl
,doi
andeprint
.) (Introduced in v0.9)dashed=false
(available for theauthoryear
,authortitle
, andverbose
bibliography styles) will print recurring author/editor names instead of replacing them by a dash. (Introduced in v0.9)maxbibnames=99
will print complete name lists for multi-author/editor works in the bibliography while truncating those lists for in-text citations. (Introduced in v1.1)Now, where to put actual customization macros? As you don't want to create a full-fledged custom style, I recommend to use the configuration file
biblatex.cfg
. This file, if available, is read bybiblatex
immediately after a style has been loaded. The (empty) original is located at/tex/latex/biblatex
in your TeX distribution directory; put a copy in the analogous location of your local TEXMF tree (and update your file database) and fill it with the redefinitions I'm (finally!) going to talk about.Addendum: You may also specify preamble options (but not bibliography/citation styles or compatibility modules) via the configuration file. Put the following into
biblatex.cfg
:Suppressing of specific BibTeX fields
For
isbn
& friends, see the introduction. Generally,biblatex
differentiates between name lists, literal lists, and other fields, and different macros have to be applied to suppress those field categories. Should you, e.g., want to remove thetranslator
,publisher
, andpagetotal
fields from the bibliography, add the following to your local copy ofbiblatex.cfg
:See sections 2.2.1 and 2.2.2 of the
biblatex
manual for a complete list of fields and the categories they belong to. To suppress specific fields for in-text-citations (e.g., when using theverbose
style), use\AtEveryCitekey
instead of\AtEveryBibitem
.Formatting of fields (and of citation postnotes)
As a general rule, inspect the "Field Formats" section of the file
biblatex.def
(location: see above). With regard to the example given in your question, look for the following:This means that for
@article
(and a bunch of other entry types), thetitle
field is put inside quotation marks. (#1
stands for the value of the field,\isdot
prevents double punctuation.) In your localbiblatex.cfg
, change the last part from{\mkbibquote{#1\isdot}}
to{#1\isdot}
, and you're set with regard to the bibliography. In case your "parent" style prints titles as part of in-text-citations, you'll have to modify thecitetitle
field in the same way.For the formatting of citation postnotes, the same principles as above apply, so I'll just post the solution to your actual question. ;-)
Bibliography – spacing and punctuation
Section 3.10.1 "Generic [Formatting] Commands and Hooks" of the manual provides the basics, the "Formatting Commands" section of
biblatex.def
contains the actual macros. With regard to your example question (How to replace unit-separator periods with commas?),needs to be redefined (using
\renewcommand
!) asBibliography – order of first names and last names
The standard styles shipped with
biblatex
use two different name formats for the bibliography:default
(used bynumeric
andalphabetic
) andsortname
(used byauthoryear
,authortitle
, andverbose
). (In-text-citations are the domain of a third name format,labelname
.) These name formats in turn utilize auxiliary macros such asfamily-given/given-family
: lead author of multi-author works is printed as "last name – first name", follow-up authors are printed as "first name – last name";family-given
: all authors are printed as "last name – first name";given-family
: you guessed it.To change the name format for, say, the
authortitle
bibliography style (by defaultfamily-given/given-family
) to, say,family-given
, apply the following:These name formats were renamed in version 3.3, see Biblatex 3.3 name formatting, before version 3.3
family
waslast
, andgiven
wasfirst
in the above. The old names continue to work, but generate warnings; the new names should be used.Bibliography – order of certain fields
Let's delve into the files
standard.bbx
and<myparentstyle>.bbx
, both of them located in the/bbx
subdirectory of yourbiblatex
folder. As per your question, you want to swap thelocation
andpublisher
fields. Suppose you encounter the following code snippet instandard.bbx
:Copy-pasting this definition to your local copy of
biblatex.cfg
and swapping the respective code lines should be a piece of cake, right? Wrong! While the "bibliography driver" shown above is functional (the example is taken from section 4.2.3 of the manual), the actual drivers are much more complex. They regularly use macros to print specific name lists, literal lists, or fields, and the macro definitions ofstandard.bbx
may be modified by<myparentstyle>.bbx
. Assuming your parent style isauthortitle
, tracing the drivers and macros will bring forth the following definition:Note the
\iflistundef
macro which will print either a comma or a colon, depending on whether thepublisher
list is defined. (The\setunit*
macro will only print its argument if the last printing command did actually print anything.) A possible redefinition – and the answer to your question – would beBy the way, redefining
publisher+location+date
will (and for the sake of consistency should) affect other entry types besides@book
.Language-specific terms
To change these, you need to modify the "localization keys" listed in section 4.9.2 of the manual. With regard to your example question, the following code does the trick:
(Actually, a long and a short form is assigned to every localization key. However, with
biblatex.cfg
it is not possible to separately override these two expressions.)Afterword
TeX.sx features a lot of questions/answers about customizing
biblatex
, with the solutions spanning everything from cute and simple macro redefinitions to venturous hacking ofbiblatex
internals. Some notable ones (no claim to be complete):Suppress "In:" for articles (by Herbert);
Put thin spaces between initials (by Will Robertson) (obsolete with v1.3);
Remove the parentheses around the year for authoryear styles (one answer by Alan Munn, another one inspired by egreg);
Reverse reference numbering (by Audrey).
Finally, here's a real-world example of tinkering with bibliography drivers.