Title: | Convert Among Citation Formats |
---|---|
Description: | Converts among many citation formats, including 'BibTeX', 'Citeproc', 'Codemeta', 'RDF XML', 'RIS', 'Schema.org', and 'Citation File Format'. A low level 'R6' class is provided, as well as stand-alone functions for each citation format for both read and write. |
Authors: | Scott Chamberlain [aut, cre] , Thierry Onkelinx [ctb] |
Maintainer: | Scott Chamberlain <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.3.0 |
Built: | 2024-12-27 03:12:27 UTC |
Source: | https://github.com/ropensci/handlr |
A tool for converting among citation formats
citeproc
ris
bibtex (requires suggested package bibtex
)
codemeta
cff
citeproc
ris
bibtex
schema.org
rdfxml (requires suggested package jsonld
)
codemeta
cff
citeproc: https://en.wikipedia.org/wiki/CiteProc
codemeta: https://codemeta.github.io/
bibtex: http://www.bibtex.org/
schema.org: https://schema.org/
Scott Chamberlain [email protected]
bibtex reader
bibtex_reader(x)
bibtex_reader(x)
x |
(character) a file path or a bibtex string |
an object of class handl
; see handl for more
requires package bibtex
, an optional package for handlr
Other readers:
cff_reader()
,
citeproc_reader()
,
codemeta_reader()
,
ris_reader()
Other bibtex:
bibtex_writer()
if (requireNamespace("bibtex", quietly=TRUE)) { (z <- system.file('extdata/crossref.bib', package = "handlr")) bibtex_reader(x = z) (z <- system.file('extdata/bibtex.bib', package = "handlr")) bibtex_reader(x = z) # many at once (z <- system.file('extdata/bib-many.bib', package = "handlr")) bibtex_reader(x = z) }
if (requireNamespace("bibtex", quietly=TRUE)) { (z <- system.file('extdata/crossref.bib', package = "handlr")) bibtex_reader(x = z) (z <- system.file('extdata/bibtex.bib', package = "handlr")) bibtex_reader(x = z) # many at once (z <- system.file('extdata/bib-many.bib', package = "handlr")) bibtex_reader(x = z) }
bibtex writer
bibtex_writer(z, key = NULL)
bibtex_writer(z, key = NULL)
z |
an object of class |
key |
(character) optional bibtex key to use. if |
an object of class BibEntry
Other writers:
cff_writer()
,
citeproc_writer()
,
codemeta_writer()
,
rdf_xml_writer()
,
ris_writer()
,
schema_org_writer()
Other bibtex:
bibtex_reader()
(z <- system.file('extdata/citeproc.json', package = "handlr")) (tmp <- citeproc_reader(z)) bibtex_writer(z = tmp) cat(bibtex_writer(z = tmp), sep = "\n") # give a bibtex key cat(bibtex_writer(tmp, "foobar89"), sep = "\n") # many at once if (requireNamespace("bibtex", quietly=TRUE)) { (z <- system.file('extdata/bib-many.bib', package = "handlr")) out <- bibtex_reader(x = z) bibtex_writer(out) }
(z <- system.file('extdata/citeproc.json', package = "handlr")) (tmp <- citeproc_reader(z)) bibtex_writer(z = tmp) cat(bibtex_writer(z = tmp), sep = "\n") # give a bibtex key cat(bibtex_writer(tmp, "foobar89"), sep = "\n") # many at once if (requireNamespace("bibtex", quietly=TRUE)) { (z <- system.file('extdata/bib-many.bib', package = "handlr")) out <- bibtex_reader(x = z) bibtex_writer(out) }
combine many handl objects
## S3 method for class 'handl' c(...)
## S3 method for class 'handl' c(...)
... |
one or more objects of class |
an object of class handl
of length equal to number of
handl
objects passed in
z <- system.file('extdata/crossref.ris', package = "handlr") cr <- ris_reader(z) z <- system.file('extdata/peerj.ris', package = "handlr") prj <- ris_reader(z) res <- c(cr, prj) res invisible(lapply(bibtex_writer(res), cat, sep = "\n\n"))
z <- system.file('extdata/crossref.ris', package = "handlr") cr <- ris_reader(z) z <- system.file('extdata/peerj.ris', package = "handlr") prj <- ris_reader(z) res <- c(cr, prj) res invisible(lapply(bibtex_writer(res), cat, sep = "\n\n"))
Citation File Format (cff) reader
cff_reader(x)
cff_reader(x)
x |
(character) a file path or a yaml string |
CFF only supports one citation, so many
will always be
FALSE
.
Required fields:
CFF v1.1.0: cff-version
, version
, message
, date-released
,
title
, authors
.
CFF v1.2.0: cff-version
, message
, title
, authors
.
We'll stop with error if any of these are missing.
You can though have many references in your CFF file
associated with the citation. references
is an optional component in
cff files. If included, we check the following:
each reference must have the 3 required fields: type, authors, title
type must be in the allowed set, see cff_reference_types
the elements within authors must each be an entity or person object https://github.com/citation-file-format/citation-file-format#entity-objects https://github.com/citation-file-format/citation-file-format#person-objects
title must be a string
an object of class handl
; see handl for more
CFF format: https://github.com/citation-file-format/citation-file-format
Other readers:
bibtex_reader()
,
citeproc_reader()
,
codemeta_reader()
,
ris_reader()
Other cff:
cff_writer()
(z <- system.file("extdata/citation.cff", package = "handlr")) res <- cff_reader(x = z) res res$cff_version res$software_version res$message res$id res$doi res$title res$author res$references # no references (z <- system.file("extdata/citation-norefs.cff", package = "handlr")) out <- cff_reader(x = z) out out$references
(z <- system.file("extdata/citation.cff", package = "handlr")) res <- cff_reader(x = z) res res$cff_version res$software_version res$message res$id res$doi res$title res$author res$references # no references (z <- system.file("extdata/citation-norefs.cff", package = "handlr")) out <- cff_reader(x = z) out out$references
cff references types
cff_reference_types
cff_reference_types
An object of class character
of length 47.
cff citation format types for references
http://bit.ly/2PRK1Vt
Citation File Format (cff) writer
cff_writer( z, path = NULL, message = "Please cite the following works when using this software." )
cff_writer( z, path = NULL, message = "Please cite the following works when using this software." )
z |
an object of class |
path |
a file path or connection; default: |
message |
a message to display.
Defaults to |
uses yaml::write_yaml
to write to yaml format that
CFF uses
text if one cff citation or list of many
CFF has required fields that can't be missing. This means that
converting from other citation types to CFF will likely require
adding the required CFF fields manually. Adding fields to a
handl
object is easy: it's really just an R list so add
named elements to it. The required CFF fields are:
CFF v1.1.0:
cff-version: add cff_version
message: add message
version: add software_version
title: add title
authors: add author
date-released: add date_published
CFF v1.2.0:
Only fields cff-version
, message
, title
and authors
are
required.
If cff_version
is not provided, the value by default is "1.2.0".
CFF format: https://github.com/citation-file-format/citation-file-format
Other writers:
bibtex_writer()
,
citeproc_writer()
,
codemeta_writer()
,
rdf_xml_writer()
,
ris_writer()
,
schema_org_writer()
Other cff:
cff_reader()
(z <- system.file('extdata/citation.cff', package = "handlr")) res <- cff_reader(x = z) res unclass(res) cff_writer(res) cat(cff_writer(res)) f <- tempfile() cff_writer(res, f) readLines(f) unlink(f) # convert from a different citation format ## see "Converting to CFF from other formats" above z <- system.file('extdata/citeproc.json', package = "handlr") w <- citeproc_reader(x = z) # cff_writer(w) # fails unless we add required fields w$cff_version <- "1.1.0" w$software_version <- "2.5" w$title <- "A cool library" w$date_published <- "2017-12-18" cff_writer(w) cat(cff_writer(w))
(z <- system.file('extdata/citation.cff', package = "handlr")) res <- cff_reader(x = z) res unclass(res) cff_writer(res) cat(cff_writer(res)) f <- tempfile() cff_writer(res, f) readLines(f) unlink(f) # convert from a different citation format ## see "Converting to CFF from other formats" above z <- system.file('extdata/citeproc.json', package = "handlr") w <- citeproc_reader(x = z) # cff_writer(w) # fails unless we add required fields w$cff_version <- "1.1.0" w$software_version <- "2.5" w$title <- "A cool library" w$date_published <- "2017-12-18" cff_writer(w) cat(cff_writer(w))
citeproc reader
citeproc_reader(x)
citeproc_reader(x)
x |
(character) a file path or string |
an object of class handl
; see handl for more
Other readers:
bibtex_reader()
,
cff_reader()
,
codemeta_reader()
,
ris_reader()
Other citeproc:
citeproc_writer()
# single z <- system.file('extdata/citeproc.json', package = "handlr") citeproc_reader(x = z) w <- system.file('extdata/citeproc2.json', package = "handlr") citeproc_reader(x = w) # many z <- system.file('extdata/citeproc-many.json', package = "handlr") citeproc_reader(x = z)
# single z <- system.file('extdata/citeproc.json', package = "handlr") citeproc_reader(x = z) w <- system.file('extdata/citeproc2.json', package = "handlr") citeproc_reader(x = w) # many z <- system.file('extdata/citeproc-many.json', package = "handlr") citeproc_reader(x = z)
citeproc writer
citeproc_writer(z, auto_unbox = TRUE, pretty = TRUE, ...)
citeproc_writer(z, auto_unbox = TRUE, pretty = TRUE, ...)
z |
an object of class |
auto_unbox |
(logical) automatically "unbox" all atomic
vectors of length 1 (default: |
pretty |
(logical) adds indentation whitespace to JSON output
(default: |
... |
further params passed to |
citeproc as JSON
Other writers:
bibtex_writer()
,
cff_writer()
,
codemeta_writer()
,
rdf_xml_writer()
,
ris_writer()
,
schema_org_writer()
Other citeproc:
citeproc_reader()
z <- system.file('extdata/citeproc.json', package = "handlr") (tmp <- citeproc_reader(z)) citeproc_writer(z = tmp) citeproc_writer(z = tmp, pretty = FALSE) cat(ris_writer(z = tmp)) # many z <- system.file('extdata/citeproc-many.json', package = "handlr") w <- citeproc_reader(x = z) citeproc_writer(w)
z <- system.file('extdata/citeproc.json', package = "handlr") (tmp <- citeproc_reader(z)) citeproc_writer(z = tmp) citeproc_writer(z = tmp, pretty = FALSE) cat(ris_writer(z = tmp)) # many z <- system.file('extdata/citeproc-many.json', package = "handlr") w <- citeproc_reader(x = z) citeproc_writer(w)
codemeta reader
codemeta_reader(x)
codemeta_reader(x)
x |
(character) a file path or string (character or json) |
an object of class handl
; see handl for more
Other readers:
bibtex_reader()
,
cff_reader()
,
citeproc_reader()
,
ris_reader()
Other codemeta:
codemeta_writer()
# single (z <- system.file('extdata/codemeta.json', package = "handlr")) codemeta_reader(x = z) # many (z <- system.file('extdata/codemeta-many.json', package = "handlr")) codemeta_reader(x = z)
# single (z <- system.file('extdata/codemeta.json', package = "handlr")) codemeta_reader(x = z) # many (z <- system.file('extdata/codemeta-many.json', package = "handlr")) codemeta_reader(x = z)
codemeta writer
codemeta_writer(z, auto_unbox = TRUE, pretty = TRUE, ...)
codemeta_writer(z, auto_unbox = TRUE, pretty = TRUE, ...)
z |
an object of class |
auto_unbox |
(logical) automatically "unbox" all atomic
vectors of length 1 (default: |
pretty |
(logical) adds indentation whitespace to JSON output
(default: |
... |
further params passed to |
an object of class json
Other writers:
bibtex_writer()
,
cff_writer()
,
citeproc_writer()
,
rdf_xml_writer()
,
ris_writer()
,
schema_org_writer()
Other codemeta:
codemeta_reader()
if (requireNamespace("bibtex", quietly=TRUE)) { (x <- system.file('extdata/crossref.bib', package = "handlr")) (z <- bibtex_reader(x)) codemeta_writer(z) } # many citeproc to schema z <- system.file('extdata/citeproc-many.json', package = "handlr") w <- citeproc_reader(x = z) codemeta_writer(w) codemeta_writer(w, pretty = FALSE)
if (requireNamespace("bibtex", quietly=TRUE)) { (x <- system.file('extdata/crossref.bib', package = "handlr")) (z <- bibtex_reader(x)) codemeta_writer(z) } # many citeproc to schema z <- system.file('extdata/citeproc-many.json', package = "handlr") w <- citeproc_reader(x = z) codemeta_writer(w) codemeta_writer(w, pretty = FALSE)
handl object
A handl
object is what's returned from the reader functions,
and what is passed to the writer functions. The handl
object is a list,
but using the print.handl
method makes it look something like:
<handl> from: codemeta many: TRUE count: 2 first 10 id/doi: https://doi.org/10.5063%2ff1m61h5x id/doi: https://doi.org/10.5063%2ff1m61h5x
You can always unclass()
the object to get the list itself.
The handl
object follows https://github.com/datacite/bolognese, which
uses the Crosscite format as its internal representation. Note that we
don't currently support writing to or reading from Crosscite.
Details on each entry are stored in the named attributes:
from: the data type the citations come from
many: is there more than 1 citation?
count: number of citations
finally, some details of the first 10 are printed
If you have a handl
object with 1 citation, it is a named list that
you can access with normal key indexing. If the result is length > 1,
the data is an unnamed list of named lists; the top level
list is unnamed, with each list within it being named.
Each named list should have the following components:
key: (string) a key for the citation, e.g., in a bibtex file
id: (string) an id for the work being referenced, often a DOI
type: (string) type of work
bibtex_type: (string) bibtex type
citeproc_type: (string) citeproc type
ris_type: (string) ris type
resource_type_general
additional_type: (string) additional type
doi: (string) DOI
b_url: (string) additional URL
title: (string) the title of the work
author: (list) authors, with each author a named list of
type: type, typically "Person"
name: full name
givenName: given (first) name
familyName: family (last) name
publisher: (string) the publisher name
is_part_of: (list) what the work is published in, or part of, a named list with:
type: (string) the type of work
title: (string) title of the work, often a journal or edited book
issn: (string) the ISSN
date_published: (string)
volume: (string) the volume, if applicable
first_page: (string) the first page
last_page: (string) the last page
description: (string) description of the work, often an abstract
license: (string) license of the work, a named list
state: (string) the state of the list
software_version: (string) software version
Citeproc formats may have extra fields that begin with csl_
handl to data.frame conversion
handl_to_df(x)
handl_to_df(x)
x |
an object of class handl |
data.frame with column following handl, with as many rows as there are citations
requires the Suggested package data.table
z <- system.file('extdata/crossref.ris', package = "handlr") res <- ris_reader(z) handl_to_df(res) (x <- HandlrClient$new(x = z)) x$as_df() # empty data.frame x$read() x$as_df() # data.frame with citation data if (requireNamespace("bibtex", quietly=TRUE)) { (z <- system.file('extdata/bib-many.bib', package = "handlr")) res2 <- bibtex_reader(x = z) handl_to_df(res2) }
z <- system.file('extdata/crossref.ris', package = "handlr") res <- ris_reader(z) handl_to_df(res) (x <- HandlrClient$new(x = z)) x$as_df() # empty data.frame x$read() x$as_df() # data.frame with citation data if (requireNamespace("bibtex", quietly=TRUE)) { (z <- system.file('extdata/bib-many.bib', package = "handlr")) res2 <- bibtex_reader(x = z) handl_to_df(res2) }
handlr client, read and write to and from all citation formats
The various inputs to the x
parameter are handled in different
ways:
file: contents read from file, we grab file extension, and we guess format based on combination of contents and file extension because file extensions may belie what's in the file
string: string read in, and we guess format based on contents of the string
DOI: we request citeproc-json format from the Crossref API
DOI url: we request citeproc-json format from the Crossref API
path
(character) non-empty if file path passed to initialize
string
(character) non-empty if string (non-file) passed to initialize
parsed
after read()
is run, the parsed content
file
(logical) TRUE
if a file passed to initialize, else FALSE
ext
(character) the file extension
format_guessed
(character) the guessed file format
doi
(character) the DOI, if any found
print()
print method for HandlrClient
objects
HandlrClient$print(x, ...)
x
self
...
ignored
new()
Create a new HandlrClient
object
HandlrClient$new(x, format = NULL, ...)
x
(character) a file path (the file must exist), a string containing contents of the citation, a DOI, or a DOI as a URL. See Details.
format
(character) one of citeproc, ris, bibtex, codemeta, cff,
or NULL
. If NULL
, we attempt to guess the format, and error if we
can not guess
...
curl options passed on to crul::verb-GET
A new HandlrClient
object
read()
read input
HandlrClient$read(format = NULL, ...)
format
(character) one of citeproc, ris, bibtex, codemeta, cff,
or NULL
. If NULL
, we attempt to guess the format, and error if we
can not guess
...
further args to the writer fxn, if any
write()
write to std out or file
HandlrClient$write(format, file = NULL, ...)
format
(character) one of citeproc, ris, bibtex, schema_org, rdfxml, codemeta, or cff
file
a file path, if NULL to stdout. for format=ris
,
number of files must equal number of ris citations
...
further args to the writer fxn, if any
as_df()
convert data to a data.frame using handl_to_df()
HandlrClient$as_df()
a data.frame
clone()
The objects of this class are cloneable with this method.
HandlrClient$clone(deep = FALSE)
deep
Whether to make a deep clone.
If $parsed
is NULL
then it's likely $read()
has not
been run - in which case we attempt to run $read()
to
populate $parsed
# read() can be run with format specified or not # if format not given, we attempt to guess the format and then read z <- system.file('extdata/citeproc.json', package = "handlr") (x <- HandlrClient$new(x = z)) x$read() x$read("citeproc") x$parsed # you can run read() then write() # or just run write(), and read() will be run for you if possible z <- system.file('extdata/citeproc.json', package = "handlr") (x <- HandlrClient$new(x = z)) cat(x$write("ris")) # read from a DOI as a url if (interactive()) { (x <- HandlrClient$new('https://doi.org/10.7554/elife.01567')) x$parsed x$read() x$parsed x$write('bibtex') } # read from a DOI if (interactive()) { (x <- HandlrClient$new('10.7554/elife.01567')) x$parsed x$read() x$write('bibtex') } # read in citeproc, write out bibtex z <- system.file('extdata/citeproc.json', package = "handlr") (x <- HandlrClient$new(x = z)) x$path x$ext x$read("citeproc") x$parsed x$write("bibtex") f <- tempfile(fileext = ".bib") x$write("bibtex", file = f) readLines(f) unlink(f) # read in ris, write out ris z <- system.file('extdata/peerj.ris', package = "handlr") (x <- HandlrClient$new(x = z)) x$path x$format_guessed x$read("ris") x$parsed x$write("ris") cat(x$write("ris")) # read in bibtex, write out ris (z <- system.file('extdata/bibtex.bib', package = "handlr")) (x <- HandlrClient$new(x = z)) x$path x$format_guessed if (requireNamespace("bibtex", quietly = TRUE)) { x$read("bibtex") x$parsed x$write("ris") cat(x$write("ris")) } # read in bibtex, write out RDF XML if (requireNamespace("bibtex", quietly = TRUE) && interactive()) { (z <- system.file('extdata/bibtex.bib', package = "handlr")) (x <- HandlrClient$new(x = z)) x$path x$format_guessed x$read("bibtex") x$parsed x$write("rdfxml") cat(x$write("rdfxml")) } # codemeta (z <- system.file('extdata/codemeta.json', package = "handlr")) (x <- HandlrClient$new(x = z)) x$path x$format_guessed x$read("codemeta") x$parsed x$write("codemeta") # cff: Citation File Format (z <- system.file('extdata/citation.cff', package = "handlr")) (x <- HandlrClient$new(x = z)) x$path x$format_guessed x$read("cff") x$parsed x$write("codemeta") # > 1 citation z <- system.file('extdata/citeproc-many.json', package = "handlr") (x <- HandlrClient$new(x = z)) x$parsed x$read() x$parsed ## schmea org x$write("schema_org") ## bibtex x$write("bibtex") ## bibtex to file f <- tempfile(fileext=".bib") x$write("bibtex", f) readLines(f) unlink(f) ## to RIS x$write("ris") ### only one per file, so not combined files <- replicate(2, tempfile(fileext=".ris")) x$write("ris", files) lapply(files, readLines) # handle strings instead of files z <- system.file('extdata/citeproc-crossref.json', package = "handlr") (x <- HandlrClient$new(x = readLines(z))) x$read("citeproc") x$parsed cat(x$write("bibtex"), sep = "\n")
# read() can be run with format specified or not # if format not given, we attempt to guess the format and then read z <- system.file('extdata/citeproc.json', package = "handlr") (x <- HandlrClient$new(x = z)) x$read() x$read("citeproc") x$parsed # you can run read() then write() # or just run write(), and read() will be run for you if possible z <- system.file('extdata/citeproc.json', package = "handlr") (x <- HandlrClient$new(x = z)) cat(x$write("ris")) # read from a DOI as a url if (interactive()) { (x <- HandlrClient$new('https://doi.org/10.7554/elife.01567')) x$parsed x$read() x$parsed x$write('bibtex') } # read from a DOI if (interactive()) { (x <- HandlrClient$new('10.7554/elife.01567')) x$parsed x$read() x$write('bibtex') } # read in citeproc, write out bibtex z <- system.file('extdata/citeproc.json', package = "handlr") (x <- HandlrClient$new(x = z)) x$path x$ext x$read("citeproc") x$parsed x$write("bibtex") f <- tempfile(fileext = ".bib") x$write("bibtex", file = f) readLines(f) unlink(f) # read in ris, write out ris z <- system.file('extdata/peerj.ris', package = "handlr") (x <- HandlrClient$new(x = z)) x$path x$format_guessed x$read("ris") x$parsed x$write("ris") cat(x$write("ris")) # read in bibtex, write out ris (z <- system.file('extdata/bibtex.bib', package = "handlr")) (x <- HandlrClient$new(x = z)) x$path x$format_guessed if (requireNamespace("bibtex", quietly = TRUE)) { x$read("bibtex") x$parsed x$write("ris") cat(x$write("ris")) } # read in bibtex, write out RDF XML if (requireNamespace("bibtex", quietly = TRUE) && interactive()) { (z <- system.file('extdata/bibtex.bib', package = "handlr")) (x <- HandlrClient$new(x = z)) x$path x$format_guessed x$read("bibtex") x$parsed x$write("rdfxml") cat(x$write("rdfxml")) } # codemeta (z <- system.file('extdata/codemeta.json', package = "handlr")) (x <- HandlrClient$new(x = z)) x$path x$format_guessed x$read("codemeta") x$parsed x$write("codemeta") # cff: Citation File Format (z <- system.file('extdata/citation.cff', package = "handlr")) (x <- HandlrClient$new(x = z)) x$path x$format_guessed x$read("cff") x$parsed x$write("codemeta") # > 1 citation z <- system.file('extdata/citeproc-many.json', package = "handlr") (x <- HandlrClient$new(x = z)) x$parsed x$read() x$parsed ## schmea org x$write("schema_org") ## bibtex x$write("bibtex") ## bibtex to file f <- tempfile(fileext=".bib") x$write("bibtex", f) readLines(f) unlink(f) ## to RIS x$write("ris") ### only one per file, so not combined files <- replicate(2, tempfile(fileext=".ris")) x$write("ris", files) lapply(files, readLines) # handle strings instead of files z <- system.file('extdata/citeproc-crossref.json', package = "handlr") (x <- HandlrClient$new(x = readLines(z))) x$read("citeproc") x$parsed cat(x$write("bibtex"), sep = "\n")
RDF XML writer
rdf_xml_writer(z, ...)
rdf_xml_writer(z, ...)
z |
an object of class |
... |
further params passed to |
package jsonld
required for this writer
RDF XML
Other writers:
bibtex_writer()
,
cff_writer()
,
citeproc_writer()
,
codemeta_writer()
,
ris_writer()
,
schema_org_writer()
if (require("jsonld") && interactive()) { library("jsonld") z <- system.file('extdata/citeproc.json', package = "handlr") (tmp <- citeproc_reader(z)) if (requireNamespace("bibtex", quietly=TRUE)) { (z <- system.file('extdata/bibtex.bib', package = "handlr")) (tmp <- bibtex_reader(z)) rdf_xml_writer(z = tmp) cat(rdf_xml_writer(z = tmp)) } }
if (require("jsonld") && interactive()) { library("jsonld") z <- system.file('extdata/citeproc.json', package = "handlr") (tmp <- citeproc_reader(z)) if (requireNamespace("bibtex", quietly=TRUE)) { (z <- system.file('extdata/bibtex.bib', package = "handlr")) (tmp <- bibtex_reader(z)) rdf_xml_writer(z = tmp) cat(rdf_xml_writer(z = tmp)) } }
ris reader (Research Information Systems)
ris_reader(x)
ris_reader(x)
x |
(character) a file path or string |
an object of class handl
; see handl for more
RIS tags https://en.wikipedia.org/wiki/RIS_(file_format)
Other readers:
bibtex_reader()
,
cff_reader()
,
citeproc_reader()
,
codemeta_reader()
Other ris:
ris_writer()
z <- system.file('extdata/crossref.ris', package = "handlr") ris_reader(z) z <- system.file('extdata/peerj.ris', package = "handlr") ris_reader(z) z <- system.file('extdata/plos.ris', package = "handlr") ris_reader(z) # from a string z <- system.file('extdata/crossref.ris', package = "handlr") my_string <- ris_writer(ris_reader(z)) class(my_string) ris_reader(my_string) # many z <- system.file('extdata/multiple-eg.ris', package = "handlr") ris_reader(z)
z <- system.file('extdata/crossref.ris', package = "handlr") ris_reader(z) z <- system.file('extdata/peerj.ris', package = "handlr") ris_reader(z) z <- system.file('extdata/plos.ris', package = "handlr") ris_reader(z) # from a string z <- system.file('extdata/crossref.ris', package = "handlr") my_string <- ris_writer(ris_reader(z)) class(my_string) ris_reader(my_string) # many z <- system.file('extdata/multiple-eg.ris', package = "handlr") ris_reader(z)
ris writer (Research Information Systems)
ris_writer(z)
ris_writer(z)
z |
an object of class |
text if one RIS citation or list of many
RIS tags https://en.wikipedia.org/wiki/RIS_(file_format)
Other writers:
bibtex_writer()
,
cff_writer()
,
citeproc_writer()
,
codemeta_writer()
,
rdf_xml_writer()
,
schema_org_writer()
Other ris:
ris_reader()
# from a RIS file z <- system.file('extdata/crossref.ris', package = "handlr") tmp <- ris_reader(z) cat(ris_writer(z = tmp)) # peerj z <- system.file('extdata/peerj.ris', package = "handlr") tmp <- ris_reader(z) cat(ris_writer(z = tmp)) # plos z <- system.file('extdata/plos.ris', package = "handlr") tmp <- ris_reader(z) cat(ris_writer(z = tmp)) # elsevier z <- system.file('extdata/elsevier.ris', package = "handlr") tmp <- ris_reader(z) cat(ris_writer(z = tmp)) z <- system.file('extdata/citeproc.json', package = "handlr") res <- citeproc_reader(z) cat(ris_writer(z = res)) # many ## combine many RIS in a handl object z <- system.file('extdata/crossref.ris', package = "handlr") cr <- ris_reader(z) z <- system.file('extdata/peerj.ris', package = "handlr") prj <- ris_reader(z) c(cr, prj) # many bibtex to ris via c method if (requireNamespace("bibtex", quietly=TRUE)) { a <- system.file('extdata/bibtex.bib', package = "handlr") b <- system.file('extdata/crossref.bib', package = "handlr") aa <- bibtex_reader(a) bb <- bibtex_reader(a) (res <- c(aa, bb)) cat(ris_writer(res), sep = "\n\n") } ## manhy Citeproc to RIS z <- system.file('extdata/citeproc-many.json', package = "handlr") w <- citeproc_reader(x = z) ris_writer(w) cat(ris_writer(w), sep = "\n")
# from a RIS file z <- system.file('extdata/crossref.ris', package = "handlr") tmp <- ris_reader(z) cat(ris_writer(z = tmp)) # peerj z <- system.file('extdata/peerj.ris', package = "handlr") tmp <- ris_reader(z) cat(ris_writer(z = tmp)) # plos z <- system.file('extdata/plos.ris', package = "handlr") tmp <- ris_reader(z) cat(ris_writer(z = tmp)) # elsevier z <- system.file('extdata/elsevier.ris', package = "handlr") tmp <- ris_reader(z) cat(ris_writer(z = tmp)) z <- system.file('extdata/citeproc.json', package = "handlr") res <- citeproc_reader(z) cat(ris_writer(z = res)) # many ## combine many RIS in a handl object z <- system.file('extdata/crossref.ris', package = "handlr") cr <- ris_reader(z) z <- system.file('extdata/peerj.ris', package = "handlr") prj <- ris_reader(z) c(cr, prj) # many bibtex to ris via c method if (requireNamespace("bibtex", quietly=TRUE)) { a <- system.file('extdata/bibtex.bib', package = "handlr") b <- system.file('extdata/crossref.bib', package = "handlr") aa <- bibtex_reader(a) bb <- bibtex_reader(a) (res <- c(aa, bb)) cat(ris_writer(res), sep = "\n\n") } ## manhy Citeproc to RIS z <- system.file('extdata/citeproc-many.json', package = "handlr") w <- citeproc_reader(x = z) ris_writer(w) cat(ris_writer(w), sep = "\n")
Schema org writer
schema_org_writer(z, auto_unbox = TRUE, pretty = TRUE, ...)
schema_org_writer(z, auto_unbox = TRUE, pretty = TRUE, ...)
z |
an object of class |
auto_unbox |
(logical) automatically "unbox" all atomic
vectors of length 1 (default: |
pretty |
(logical) adds indentation whitespace to JSON output
(default: |
... |
further params passed to |
an object of class json
Other writers:
bibtex_writer()
,
cff_writer()
,
citeproc_writer()
,
codemeta_writer()
,
rdf_xml_writer()
,
ris_writer()
if (requireNamespace("bibtex", quietly=TRUE)) { (z <- system.file('extdata/bibtex.bib', package = "handlr")) (tmp <- bibtex_reader(z)) schema_org_writer(tmp) schema_org_writer(tmp, pretty = FALSE) } # many citeproc to schema z <- system.file('extdata/citeproc-many.json', package = "handlr") w <- citeproc_reader(x = z) schema_org_writer(w) schema_org_writer(w, pretty = FALSE)
if (requireNamespace("bibtex", quietly=TRUE)) { (z <- system.file('extdata/bibtex.bib', package = "handlr")) (tmp <- bibtex_reader(z)) schema_org_writer(tmp) schema_org_writer(tmp, pretty = FALSE) } # many citeproc to schema z <- system.file('extdata/citeproc-many.json', package = "handlr") w <- citeproc_reader(x = z) schema_org_writer(w) schema_org_writer(w, pretty = FALSE)