![Bibliografia na ordem inversa de entrada em .bib](https://rvso.com/image/266401/Bibliografia%20na%20ordem%20inversa%20de%20entrada%20em%20.bib.png)
Quando eu digito:
@ARTICLE{article1,
author = {AAA},
title = {New Method1},
year ={2013},
journal = {SuperJournal},
}
@ARTICLE{article2,
author = {BBB},
title = {New Method2},
year ={2013},
journal = {SuperJournal},
}
a ordem desejável é
[1] BBB, Artigo2,...
[2] AAA, Artigo 1,..
Em outras palavras, quero o oposto do que \bibliographystyle{unsrt}
me dá. Qualquer um?
EDITAR. Estendo a pergunta adicionando mais informações. Quero importar arquivos depublications.bib usando o pacote multibib.
documentclass[11pt,a4paper,sans]{moderncv}
\moderncvstyle{classic}
\moderncvcolor{blue}
\makeatletter
\renewcommand*{\bibliographyitemlabel}{\@biblabel{\arabic{enumiv}}}
\makeatother
\renewcommand*{\bibliographyitemlabel}{[\arabic{enumiv}]}
% bibliography with mutiple entries
\usepackage{multibib}
\newcites{article}{{Articles}}
.
.
.
\section{Publications}
\nocitearticle{article1, article2}
\bibliographystylearticle{unsrt}
\bibliographyarticle{publications}
\end{document}
Responder1
Você pode usar o estilo bibliografia plain
. As etapas de compilação são mostradas pelas regras do arara
.
% arara: pdflatex
% arara: bibtex
% arara: pdflatex
% arara: pdflatex
\documentclass{article}
\usepackage{filecontents}
\begin{filecontents}{\jobname.bib}
@ARTICLE{article1,
author = {AAA},
title = {New Method1},
year ={2013},
journal = {SuperJournal},
}
@ARTICLE{article2,
author = {BBB},
title = {New Method2},
year ={2013},
journal = {SuperJournal},
}
\end{filecontents}
\begin{document}
\cite{article2} and \cite{article1}
\bibliography{\jobname}
\bibliographystyle{plain}
\end{document}
Com o resultado:
Responder2
Se o .bib
arquivo não tiver nada de estranho, ou seja, ele contém apenas entradas @article
ou @book
(todos os tipos de entradas são suportadas, mas não @STRING
ou @COMMENT
), o seguinte deve ser feito.
Lemos o .bib
arquivo construindo uma lista de chaves em ordem inversa e, em seguida, emitimos o \nocite
comando relevante.
\begin{filecontents*}{\jobname.bib}
@ARTICLE{article1,
author = {AAA},
title = {New Method1},
year ={2013},
journal = {SuperJournal},
}
@ARTICLE{article2,
author = {BBB},
title = {New Method2},
year ={2013},
journal = {SuperJournal},
}
@ARTICLE{article3,
author = {CCC},
title = {New Method2},
year ={2013},
journal = {SuperJournal},
}
@ARTICLE{article4,
author = {DDD},
title = {New Method2},
year ={2013},
journal = {SuperJournal},
}
@ARTICLE{article5,
author = {EEE},
title = {New Method2},
year ={2013},
journal = {SuperJournal},
}
\end{filecontents*}
\documentclass{article}
\usepackage{xparse}
\ExplSyntaxOn
\NewDocumentCommand{\readbib}{ m }
{
\makaroni_readbib:n { #1 }
}
\clist_new:N \g_makaroni_keys_clist
\group_begin:
\char_set_catcode_active:n { `\^^A }
\cs_new_protected:Npn \makaroni_readbib:n #1
{
\group_begin:
\char_set_catcode_active:n { `\@ }
\group_begin:
\char_set_lccode:nn { `\^^A } { `\@ }
\tl_to_lowercase:n
{
\group_end:
\cs_set_eq:NN ^^A \__makaroni_active_at:w
}
\input{#1.bib}
\group_end:
\exp_args:Nx \nocite { \g_makaroni_keys_clist }
}
\group_end:
\cs_new_protected:Npn \__makaroni_active_at:w #1#
{
\__makaroni_process_entry:n
}
\cs_new_protected:Npn \__makaroni_process_entry:n #1
{
\__makaroni_add_key:w #1 \q_stop
}
\cs_new_protected:Npn \__makaroni_add_key:w #1 , #2 \q_stop
{
\clist_gput_left:Nn \g_makaroni_keys_clist { #1 }
}
\ExplSyntaxOff
\begin{document}
\readbib{\jobname}
\bibliographystyle{unsrt}
\bibliography{\jobname}
\end{document}
O filecontents*
ambiente serve apenas para tornar o exemplo independente.
O método é semelhante ao empregado em usebib.sty
. O @
é ativado e definido para leitura até a primeira chave; então é chamada outra macro que absorve toda a entrada e chama outra que isola a chave, adicionando-a à esquerda de uma variável da lista de vírgula. Então, após finalizar o arquivo a ser lido, um \nocite
comando é emitido com o conteúdo (expandido) do clist como argumento.