texlive[60477] Master/texmf-dist: biblatex-gb7714-2015 (11sep21)

commits+karl at tug.org commits+karl at tug.org
Sat Sep 11 22:37:43 CEST 2021


Revision: 60477
          http://tug.org/svn/texlive?view=revision&revision=60477
Author:   karl
Date:     2021-09-11 22:37:42 +0200 (Sat, 11 Sep 2021)
Log Message:
-----------
biblatex-gb7714-2015 (11sep21)

Modified Paths:
--------------
    trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/README.md
    trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/biblatex-gb7714-2015.pdf
    trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/biblatex-gb7714-2015.tex
    trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015.bbx
    trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015.cbx
    trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ay.bbx
    trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ay.cbx
    trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ms.bbx
    trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ms.cbx
    trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015mx.bbx
    trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015mx.cbx

Added Paths:
-----------
    trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/gb7714texttobib.pl

Modified: trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/README.md
===================================================================
--- trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/README.md	2021-09-11 20:37:25 UTC (rev 60476)
+++ trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/README.md	2021-09-11 20:37:42 UTC (rev 60477)
@@ -1,4 +1,4 @@
-<b>Date of last change: 2021-08-19 to version v1.0z</b>
+<b>Date of last change: 2021-09-11 to version v1.1a</b>
 
 
 # biblatex-gb7714-2015: a biblatex style  package
@@ -95,7 +95,7 @@
 * [biblatex-map bib文件修改工具](https://github.com/hushidong/biblatex-map/)
 * [biblatex-check bib文件检查工具](https://github.com/Pezmc/BibLatex-Check)
 * [biblatex-caspervector: caspervector 设计的中文参考文献样式](https://github.com/CasperVector/biblatex-caspervector)
-* [gbt7714-bibtex-style: GB/T7714-2015 标准的bst实现版本](https://github.com/zepinglee/gbt7714-bibtex-style)
+* [gbt7714-bibtex-style: GB/T7714-2015 标准的bst实现版本](https://github.com/CTeX-org/gbt7714-bibtex-style)
 * [LaTeX学习网站](http://www.latexstudio.net/)
 * [LaTeX交流论坛](http://www.ctex.org/)
 
@@ -680,6 +680,13 @@
 请邮件联系hzzmail at 163.com或在项目内发issue提问即可。
 
 
+* <b>注意帮助的文档的查询顺序?</b>
+
+一般用户的话查:biblatex-gb7714-2015.pdf,biblatex-solution-to-latex-bibliography.pdf,biblatex-zh-cn.PDF。
+宏包作者的话查:gb7714-2015*.C/BBX,biblatex.PDF,numeric/authoryear.c/BBX,standard.bbx,biblatex.def,biblatex.sty,english.lbx
+注意别忘了lbx文件。
+
+
 #### 4.2 Bibliography format/文献表著录格式
 
 * <b>请问可以在参考文献表中实现类似于word那样的与文献内容等间距标签对齐格式么?</b>
@@ -966,6 +973,29 @@
 可通过设置选项uniquelist=false实现,该设置标签中的作者只会是指定的1个:
 
 ```\usepackage[backend=biber,style=gb7714-2015ay,uniquelist=false]{biblatex}```
+
+
+* <b>请问希望正文中作者年制的标注(引用)标签希望作者给出3个,而且最后一个作者的前面用和及&符号链接,该怎么处理?</b>
+	
+
+首先设置标注标签中的作者的最大数量为3个:
+
+```\usepackage[backend=biber,style=gb7714-2015ay,maxcitenames=3]{biblatex}```
+
+然后修改标注中的本地化字符串:
+
+```
+\DefineBibliographyStrings{english}{
+        andincitecn = {\str at andcn},%将标注中的分开,便于与文献表中的区分
+        andincite   = {\&}}
+```
+
+最后重新定义finalandcomma标点,注意这里与语言相关的标点,需要用DefineBibliographyExtras命令定义。
+
+```
+\DefineBibliographyExtras{english}{\def\finalandcomma{}}%
+```
+
 		
 		
 		
@@ -1515,6 +1545,7 @@
 * 2021/04/03 v1.0x,ctan
 * 2021/05/06 v1.0y,ctan
 * 2021/08/19 v1.0z,ctan
+* 2021/09/11 v1.1a,ctan
 
 
 

Modified: trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/biblatex-gb7714-2015.pdf
===================================================================
(Binary files differ)

Modified: trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/biblatex-gb7714-2015.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/biblatex-gb7714-2015.tex	2021-09-11 20:37:25 UTC (rev 60476)
+++ trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/biblatex-gb7714-2015.tex	2021-09-11 20:37:42 UTC (rev 60477)
@@ -1268,8 +1268,26 @@
 %上一段2016-1114更新,下面是以前的说法。
 %\qd{根据文种文献集中的要求,修改了nyt排序格式,增加了userb作为name前的排序域,当有需求进行多文种分集且有特殊顺序时,在bib文件中给相应文种的文献设置适合排序的字符串。比如中文文献设置为cn,英文文献设置为en,法文文献设置为fr,那么排序中,相应的中文文献排在最前面,英文文献在中间,法文文献最后,因为升序情况下字母顺序是c然后e然后f。}
 
-打印出的文献表主要有两个部分的格式需要控制,一是文献表的段落格式,二是文献表中各条文献的著录格式:
+打印出的文献表主要有三个部分的格式需要控制,一是文献表的标题格式,二是文献表的段落格式,三是文献表中各条文献的著录格式:
 
+\subsubsection{标题格式控制}
+
+标题内容的设置有三种方式,这里再重复一下:一是直接在printbibliography命令中利用选项title设置,二是gbctexset=true时,重定义bibname和refname来设置,三是gbctexset=true是false时,利用本地化字符串进行设置。具体参见gbctexset选项。
+
+标题格式的设置主要是通过重定义参考文献环境的heading进行,比如:
+
+\begin{example}{文献表标题格式}{eg:biblist:title}
+\begin{texlist}
+%将参考文献标题设置为段落的层级,若是其它层级则使用对应的命令,比如chapter,section等
+\defbibheading{bibliography}[\bibname]{%
+\paragraph{#1}}%
+\end{texlist}
+\end{example}
+
+更多的设置方法,请参考:
+\href{https://github.com/hushidong/biblatex-solution-to-latex-bibliography/blob/master/biblatex-solution-to-latex-bibliography.pdf}%
+{biblatex高级使用方法和样式包设计实现方法}
+
 \subsubsection{段落格式控制}
 
 \paragraph{\heiti 文献表字体、颜色、间距、缩进控制} 为方便用户改变文献表段落格式、内容字体和颜色等,在 biblatex 提供的 \verb|\bibfont| 命令基础上,

Added: trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/gb7714texttobib.pl
===================================================================
--- trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/gb7714texttobib.pl	                        (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/gb7714texttobib.pl	2021-09-11 20:37:42 UTC (rev 60477)
@@ -0,0 +1,1705 @@
+##%
+##% ---------------------------------------------------------------
+##% gb7714texttobib--- A transformation tool for GB/T 7714-2015 style 
+##% bibliography text to bib source file
+##% 
+##% Maintained by huzhenzhen
+##% Homepage: <https://github.com/hushidong/biblatex-gb7714-2015>
+##% history:
+##% 	2017/02/26 v1.0g
+##% 	2021/09/04 add compatablity for text with no space after punctuations.
+##% E-mail: 
+##% 	hzzmail at 163.com
+##% Released under the LaTeX Project Public License v1.3c or later
+##% usage:
+##% 	perl gb7714texttobib.pl in=textfilename out=bibfilename
+##% options(need to do):
+##% 	style=ay or default
+##% 	key=ay or default
+##%
+##% ---------------------------------------------------------------
+#%Target:: 将pdf文档中拷出的参考文献文本转换成bib文件,文本文件中的一条参考文献为一行
+#%Method:: 利用perl进行文本处理,处理和判断的两个重要方面是:
+#          分析分割后的文本的位置和内容,使用的是正则表达式匹配,主要两种方式
+#		   1.根据标点和本文特征一部分一部分的解析,比如book条目处理
+#		   2.直接列出所有可能的正则表达式一个个匹配,比如article条目处理
+#%Date  :: 2017-02-22
+#%Note  :: 1.网址之类如果解析出错,应确认其前导词http://之前没有空格
+#          2.有些以.连接有从属关系的机构作者,可以把.后的空格去掉便于正确解析
+#          3.有些尽管解析到的域不是真实的域,但不影响著录格式(显示效果),相应条目的域
+#            可以在bib文件中完善,尽管从实用角度并不需要这么做。
+#
+##% ---------------------------------------------------------------
+##% todo: 1. pdf 的比较?
+##% obsolete intro:
+##% 	  1.源文件文档如果个别地方不符合规范,可以修改一下
+##% 	   (a):inbook/standard类中,当出现//后面第二项是booktitle且其中存在:时,先把父标题的冒号改成colon,比如
+##%			[M]//李承森. 宋史: 第 1 册. 北京: 中华书局. 应把宋史后的冒号改掉
+##% 	    [S]//全国文献工作标准化技术委员会. 文献工作国家标准汇编: 3. 北京: 中国标准出版社, 1988: 59–92.
+##% ---------------------------------------------------------------
+
+
+foreach $file(@ARGV){
+	print 'file:',$file,"\n";
+	if($file=~m/in=/){
+	($infile)=($file=~m/in=(.*)/)
+	}
+	if($file=~m/out=/){
+	($outfile)=($file=~m/out=(.*)/)
+	}
+}
+
+open (FHR,"<$infile");
+open (FHW,">$outfile");
+print FHW '% Encoding: UTF-8',"\n";
+
+ at references=<FHR>;#将所有的文献存为@references数组,各文献以<行>为单位进行区分
+
+
+#有些文本标点后面没有空格,所以先对这个问题进行处理
+#在所有的关键标点后面加上空格
+#20210904,HZZ
+foreach $stra (@references) {
+	print "$stra\n";
+	$stra=~s/\.(\S)/\. $1/g;
+	$stra=~s/\,(\S)/\, $1/g;
+	$stra=~s/\:(\S)/\: $1/g;
+	print "$stra\n";
+	}
+print "@references\n";
+
+
+
+$ns=1;
+$ne=@references;
+$nline=0;
+foreach $reference(@references){
+
+	$nline=$nline+1;
+	if($nline<$ns){next;} #先跳过几行进行,配合后面的last进行当行测试
+
+	while($reference=~m/–/){
+		$reference=~s/–/-/;#直接利用正则表达式更正页码/日期/网址中的连字符
+	}
+	print "ref: $reference ";#打印各文献的内容
+
+	$lenstr=length($reference);
+	print "lenstr=$lenstr\n";
+	$lenstr=rindex $reference."\$","\$";
+	print "lenstr=$lenstr\n";
+
+	if ($lenstr>1){
+		undef	$entrytype;
+		undef	$author;
+		undef	$title;
+		undef	$journal;
+		undef	$translator;
+		undef	$bookauthor;
+		undef	$booktitle;
+		undef	$version;
+		undef	$address;
+		undef	$publisher;
+		undef	$institution;
+		undef	$year;
+		undef	$type;
+		undef	$date;
+		undef	$volume;
+		undef	$number;
+		undef	$pages;
+		undef	$eventdate;
+		undef	$urldate;
+		undef	$url;
+		undef	$doi;
+		undef	$note;
+		undef	$eventyvn; 
+		undef	$endeventyvn;
+		undef	$eventdate; 
+		undef	$eventvol; 
+		undef	$eventnum;
+		undef	$endeventdate; 
+		undef	$endeventvol; 
+		undef	$endeventnum;
+		
+		#---------------------------------------------------------------
+		#条目类型:期刊和期刊中析出的文献/periodical、article
+		#---------------------------------------------------------------
+		if(1){
+		if($reference=~m/\[J\]/){
+			#避免在标题中存在在冒号的问题,所以从[J]开始匹配,通常也不需要从[J/OL]开始因为periodical通常不会出现online
+			#2021.09.04,hzz,修改
+			if($reference=~m/:\s/ and $reference=~m/\[J\].*:\s\D/){#根据存在出版社前的冒号加空格区分
+				print 'this entry is periodical',"\n";
+				$entrytype='periodical';
+			}else{
+				print 'this entry is article',"\n";
+				$entrytype='article';
+			}
+		}
+		
+		if($entrytype eq 'periodical'){#字符串比较用eq而数字比较用==,如果用==那么两边都是1,则是真
+			$regexformach='\[J\]\.';
+			&bfidentifier;
+			
+			($preadderess, $pospublisher)=($reference=~m/\[J\]\.(.*):\s(.*)/);
+			print 'preadderess =',$preadderess,"\n";
+			print 'pospublisher=',$pospublisher,"\n";
+			($eventyear, $address)=($preadderess=~m/(.*)\.\s(.*)/);
+			print 'eventyear   =',$eventyear,"\n";
+			print 'address     =',$address,"\n";
+			($eventyvn, $endeventyvn)=($eventyear=~m/(.*)\-(.*)/);#yvn表示year,volume,number
+			print 'eventyvn    =',$eventyvn,"\n";
+			print 'endeventyvn =',$endeventyvn,"\n"; 
+			if($eventyvn=~m/.*,.*/){#存在逗号表明有卷信息
+				($eventdate, $eventvol, $eventnum)=($eventyvn=~m/\s*(.*),\s(.*)\((.*)\)/);#yvn表示year,volume,number
+				print 'eventdate    =',$eventdate,"\n";
+				print 'eventvol     =',$eventvol,"\n"; 
+				print 'eventnum     =',$eventnum,"\n"; 
+				if($endeventyvn){
+					($endeventdate, $endeventvol, $endeventnum)=($endeventyvn=~m/\s*(.*),\s(.*)\((.*)\)/);#yvn表示year,volume,number
+					print 'endeventdate =',$endeventdate,"\n";
+					print 'endeventvol  =',$endeventvol,"\n"; 
+					print 'endeventnum  =',$endeventnum,"\n"; 
+				}
+			}else{
+				($eventdate, $eventnum)=($eventyvn=~m/\s*(.*)\((.*)\)/);#yvn表示year,volume,number
+				print 'eventdate    =',$eventdate,"\n";
+				print 'eventvol     =',$eventvol,"\n"; 
+				print 'eventnum     =',$eventnum,"\n"; 
+				if($endeventyvn){
+					($endeventdate, $endeventnum)=($endeventyvn=~m/\s*(.*)\((.*)\)/);#yvn表示year,volume,number
+					print 'endeventdate =',$endeventdate,"\n";
+					print 'endeventvol  =',$endeventvol,"\n"; 
+					print 'endeventnum  =',$endeventnum,"\n"; 
+				}
+			}
+			if($endeventdate){
+				$date=$eventdate.'-'.$endeventdate;
+			}else{
+				$date=$eventdate
+			}
+			if($endeventvol){
+				$volume=$eventvol.'-'.$endeventvol;
+			}else{
+				$volume=$eventvol
+			}
+			if($endeventnum){
+				$number=$eventnum.'-'.$endeventnum;
+			}else{
+				$number=$eventnum
+			}
+			print 'date      =',$date,"\n";
+			print 'volume    =',$volume,"\n"; 
+			print 'number    =',$number,"\n"; 
+			($publisher)=($pospublisher=~m/(.*),/);
+			print 'publisher =',$publisher,"\n";
+		}
+		
+		if($entrytype eq 'article'){
+			$regexformach='\[J\]\.';
+			&bfidentifier;
+		
+			$flagmatched=0;
+			$regexbfjournal='\]\.\s(.*),\s(.*),\s(.*)\((.*)\):\s(.*)\.';#包括全部信息
+			if($reference=~m/$regexbfjournal/){
+				($journal,$date,$volume,$number,$pages)=($reference=~m/$regexbfjournal/);
+				$flagmatched=1;
+				print '包括全部信息',"\n";
+			}
+			$regexbfjournal='\]\.\s(.*),\s(.*),\s(.*)\((.*)\)\.';#没有页码
+			if($reference=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$volume,$number)=($reference=~m/$regexbfjournal/);
+				$flagmatched=1;
+				print '没有页码',"\n";
+			}
+			$regexbfjournal='\]\.\s(.*),\s(.*),\s(.*):\s(.*)\.';#没有期
+			if($reference=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$volume,$pages)=($reference=~m/$regexbfjournal/);
+				$flagmatched=1;
+				print '没有期',"\n";
+			}
+			$regexbfjournal='\]\.\s(.*),\s(.*)\((.*)\):\s(.*)\.';#没有卷/年
+			if($reference=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$number,$pages)=($reference=~m/$regexbfjournal/);
+				$flagmatched=1;
+				if($date!~m/\d{4}/){
+				$volume=$date;
+				$date='';
+				}
+				print '没有卷/年',"\n";
+			}
+			$regexbfjournal='\]\.\s(.*),\s(.*),\s(.*)\.';#没有页码,期
+			if($reference=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$volume)=($reference=~m/$regexbfjournal/);
+				$flagmatched=1;
+				print '没有页码,期',"\n";
+			}
+			$regexbfjournal='\]\.\s(.*),\s(.*)\((.*)\)\.';#没有页码,卷/年
+			if($reference=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$number)=($reference=~m/$regexbfjournal/);
+				$flagmatched=1;
+				if($date!~m/\d{4}/){
+				$volume=$date;
+				$date='';
+				}
+				print '没有页码,卷/年',"\n";
+			}
+			$regexbfjournal='\]\.\s(.*),\s(.*):\s(.*)\.';#没有卷/年,期
+			if($reference=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$pages)=($reference=~m/$regexbfjournal/);
+				$flagmatched=1;
+				if($date!~m/\d{4}/){
+				$volume=$date;
+				$date='';
+				}
+				print '没有卷/年,期',"\n";
+			}
+			
+			if($flagmatched==0){
+				print 'the text after title was not matched, please add a regex for the current entry in the perl source code!',"\n";
+				print '当前条目标题之后的内容没有匹配的正则表达式,请在perl代码中增加适合该条目正则表达式!',"\n";
+			}
+			
+			print 'journal =',$journal,"\n";
+			print 'date    =',$date,"\n";
+			print 'volume  =',$volume,"\n";
+			print 'number  =',$number,"\n";
+			print 'pages   =',$pages,"\n";
+		
+		}
+			
+		#判断期刊中析出的文献,带url
+		if($reference=~m/\[J\/OL\]/){
+			print 'this entry is article with url',"\n";
+			$entrytype='article';
+			
+			$regexformach='\[J\/OL\]\.';
+			&bfidentifier;
+			
+			($postitle)=($reference=~m/\[J\/OL\]\.\s(.*)/);
+			if($postitle=~m/\[.*\]/){#存在urldate
+				($preurldate,$urldate,$posurl)=($postitle=~m/(.*)\[(.*)\]\.\s(.*)/);
+			}else{#不存在urldate
+				($preurldate,$posurl)=($postitle=~m/(.*)(http:.*)/);
+			}
+			unless($preurldate=~m/\.$/){$preurldate=$preurldate.'.';}#加个点统一上面两种方式
+			
+			#处理url和doi
+			$regexposurl='(.*)doi:\s(.*)';#处理url和doi
+			if($posurl=~m/$regexposurl/i){
+				($url,$doi)=($posurl=~m/$regexposurl/i);
+			}else{
+				$url=$posurl;
+			}
+			
+			#处理urldate前的内容,基本article不带url的情况相同
+			$flagmatched=0;
+			$regexbfjournal='(.*),\s(.*),\s(.*)\((.*)\):\s(.*)\.';#包括全部信息
+			if($preurldate=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$volume,$number,$pages)=($preurldate=~m/$regexbfjournal/);
+				$flagmatched=1;
+			}
+			$regexbfjournal='(.*),\s(.*),\s(.*)\((.*)\)\.';#没有页码
+			if($preurldate=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$volume,$number)=($preurldate=~m/$regexbfjournal/);
+				$flagmatched=1;
+			}
+			$regexbfjournal='(.*),\s(.*),\s(.*):\s(.*)\.';#没有期
+			if($preurldate=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$volume,$pages)=($preurldate=~m/$regexbfjournal/);
+				$flagmatched=1;
+			}
+			$regexbfjournal='(.*),\s(.*)\((.*)\):\s(.*)\.';#没有卷/年
+			if($preurldate=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$number,$pages)=($preurldate=~m/$regexbfjournal/);
+				$flagmatched=1;
+				if($date!~m/\d{4}/){
+				$volume=$date;
+				$date='';
+				}
+			}
+			$regexbfjournal='(.*),\s(.*),\s(.*)\.';#没有页码,期
+			if($preurldate=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$volume)=($preurldate=~m/$regexbfjournal/);
+				$flagmatched=1;
+			}
+			$regexbfjournal='(.*),\s(.*)\((.*)\)\.';#没有页码,卷/年
+			if($preurldate=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$number)=($preurldate=~m/$regexbfjournal/);
+				$flagmatched=1;
+				if($date!~m/\d{4}/){
+				$volume=$date;
+				$date='';
+				}
+			}
+			$regexbfjournal='(.*),\s(.*):\s(.*)\.';#没有卷/年,期
+			if($preurldate=~m/$regexbfjournal/ and $flagmatched==0){
+				($journal,$date,$pages)=($preurldate=~m/$regexbfjournal/);
+				$flagmatched=1;
+				if($date!~m/\d{4}/){
+				$volume=$date;
+				$date='';
+				}
+			}
+			
+			if($flagmatched==0){
+				print 'the text after title was not matched, please add a regex for the current entry in the perl source code!',"\n";
+				print '当前条目标题之后的内容没有匹配的正则表达式,请在perl代码中增加适合该条目正则表达式!',"\n";
+			}
+			
+			print 'journal =',$journal,"\n";
+			print 'date    =',$date,"\n";
+			print 'volume  =',$volume,"\n";
+			print 'number  =',$number,"\n";
+			print 'pages   =',$pages,"\n";
+			print 'urldate =',$urldate,"\n";
+			print 'url     =',$url,"\n";
+			print 'doi     =',$doi,"\n";
+
+
+		}
+		}
+		
+		#---------------------------------------------------------------
+		#条目类型:判断报纸中析出的文献/newspaper
+		#---------------------------------------------------------------
+		if(1){
+		if($reference=~m/\[N\]/){
+			print 'this entry is newspaper',"\n";
+			$entrytype='newspaper';
+			$note='news';
+			$regexnewsflag='\[N\]';
+			$onlineflag=0;
+		}
+		if($reference=~m/\[N\/OL\]/){
+			print 'this entry is newspaper with url',"\n";
+			$entrytype='newspaper';
+			$note='news';
+			$regexnewsflag='\[N\/OL\]';
+			$onlineflag=1;
+		}
+		if($entrytype eq 'newspaper'){
+			if($onlineflag==1){
+				$regexformach='\[N\/OL\]';
+				&bfidentifier;
+				
+				print 'has url',"\n";
+				$flagmatched=0;
+				$regexnewspostitle='\.\s(.*),\s(.*)\((.*)\)\s*\[(.*)\]\.\s(.*)';
+				if($reference=~m/$regexnewsflag$regexnewspostitle/ and $flagmatched==0){
+				$flagmatched=1;
+				($journal,$date,$number,$urldate,$posurl)=($reference=~m/$regexnewsflag$regexnewspostitle/);}
+				$regexnewspostitle='\.\s(.*),\s(.*)\s*\[(.*)\]\.\s(.*)';
+				if($reference=~m/$regexnewsflag$regexnewspostitle/ and $flagmatched==0){
+				$flagmatched=1;
+				($journal,$date,$urldate,$posurl)=($reference=~m/$regexnewsflag$regexnewspostitle/);}
+				if($flagmatched==0){
+				print 'the text after title was not matched, please add a regex for the current entry in the perl source code!',"\n";
+				print '当前条目标题之后的内容没有匹配的正则表达式,请在perl代码中增加适合该条目正则表达式!',"\n";
+				}
+			}else{
+				$regexformach='\[N\]';
+				&bfidentifier;
+				
+				print 'no url',"\n";
+				$regexnewspostitle='\.\s(.*),\s(.*)\((.*)\)';
+				($journal,$date,$number)=($reference=~m/$regexnewsflag$regexnewspostitle/);
+			}
+			#处理url和doi
+			$regexposurl='(.*)doi:\s(.*)';#处理url和doi
+			if($posurl=~m/$regexposurl/i){
+				($url,$doi)=($posurl=~m/$regexposurl/i);
+			}else{
+				$url=$posurl;
+			}
+			
+			# print 'journal =',$journal,"\n";
+			# print 'date    =',$date,"\n";
+			# print 'volume  =',$volume,"\n";
+			# print 'number  =',$number,"\n";
+			# print 'pages   =',$pages,"\n";
+			# print 'urldate =',$urldate,"\n";
+			# print 'url     =',$url,"\n";
+			# print 'doi     =',$doi,"\n";
+		}
+		}
+		
+			
+		#---------------------------------------------------------------
+		#条目类型:论文集中析出的文献/inproceedings
+		#---------------------------------------------------------------
+		if(1){#\/\/
+			if ($reference=~m/\[C\/OL\]\/\//){
+				$entrytype='inproceedings';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[C\/OL\]\/\/';
+				&bfidentifier;
+				
+				$regexformach='C\/OL\]\/\/';
+				&bfaddressinbook;
+			
+				&afpublisherbookurl;
+			}elsif($reference=~m/\[C\]\/\//){
+				$entrytype='inproceedings';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[C\]\/\/';
+				&bfidentifier;
+				
+				$regexformach='C\]\/\/';
+				&bfaddressinbook;
+				
+				&afpublisherbook;
+			}
+			
+			if ($entrytype eq 'inproceedings'){
+				if ($address=~m/\[S\.l\.\]/ or $address=~m/出版地不详/) {#当存在英文的[s.n.]
+					$address=""; 
+				}
+				if ($publisher=~m/\[s\.n\.\]/ or $publisher=~m/出版者不详/) {#当存在英文的[s.n.]
+					$publisher=""; 
+				}
+				$date=$year;
+			}
+			
+		}
+		
+		
+		#---------------------------------------------------------------
+		#条目类型:论文集/proceedings 
+		#---------------------------------------------------------------
+		if(1){
+			if ($reference=~m/\[C\/OL\]\./){
+				$entrytype='proceedings';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[C\/OL\]\.';
+				&bfidentifier;
+				
+				$regexformach='C\/OL\]\.';
+				&bfaddressbook;
+			
+				&afpublisherbookurl;
+			}elsif($reference=~m/\[C\]\./){
+				$entrytype='proceedings';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[C\]\.';
+				&bfidentifier;
+				
+				$regexformach='C\]\.';
+				&bfaddressbook;
+				
+				&afpublisherbook;
+			}
+			
+			if ($entrytype eq 'proceedings'){
+				if ($address=~m/\[S\.l\.\]/ or $address=~m/出版地不详/) {#当存在英文的[s.n.]
+					$address=""; 
+				}
+				if ($publisher=~m/\[s\.n\.\]/ or $publisher=~m/出版者不详/) {#当存在英文的[s.n.]
+					$publisher=""; 
+				}
+				$date=$year;
+				print 'date=',"$date";
+			}
+		}
+		
+		
+		
+		
+		#---------------------------------------------------------------
+		#条目类型:未出版物/unpublished
+		#---------------------------------------------------------------
+		if(1){
+			if ($reference=~m/\[Z\/OL\]\./){
+				$entrytype='unpublished';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[Z\/OL\]\.';
+				&bfidentifier;
+				
+				$regexformach='Z\/OL\]\.';
+				&bfaddressbook;
+			
+				&afpublisherbookurlb;
+			}elsif($reference=~m/\[Z\]\./){
+				$entrytype='unpublished';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[Z\]\.';
+				&bfidentifier;
+				
+				$regexformach='Z\]\.';
+				&bfaddressbook;
+				
+				&afpublisherbookb;
+			}
+			
+			if ($entrytype eq 'unpublished'){
+				$date=$year;
+				print 'date=',"$date";
+			}
+		}
+		
+			
+		#---------------------------------------------------------------
+		#条目类型:手册、档案/manual
+		#---------------------------------------------------------------
+		if(1){
+			if ($reference=~m/\[A\/OL\]\./){
+				$entrytype='manual';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[A\/OL\]\.';
+				&bfidentifier;
+				
+				$regexformach='A\/OL\]\.';
+				&bfaddressbook;
+			
+				&afpublisherbookurlb;
+			}elsif($reference=~m/\[A\]\./){
+				$entrytype='manual';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[A\]\.';
+				&bfidentifier;
+				
+				$regexformach='A\]\.';
+				&bfaddressbook;
+				
+				&afpublisherbookb;
+			}
+			
+			if ($entrytype eq 'manual'){
+				$date=$year;
+				print 'date=',"$date";
+			}
+		}
+		
+		
+		
+		#---------------------------------------------------------------
+		#条目类型:报告/report
+		#---------------------------------------------------------------
+		if(1){
+			if ($reference=~m/\[R\/OL\]\./){
+				$entrytype='report';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[R\/OL\]\.';
+				&bfidentifier;
+				
+				$regexformach='R\/OL\]\.';
+				&bfaddressbook;
+			
+				&afpublisherbookurlb;
+			}elsif($reference=~m/\[R\]\./){
+				$entrytype='report';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[R\]\.';
+				&bfidentifier;
+				
+				$regexformach='R\]\.';
+				&bfaddressbook;
+				
+				&afpublisherbookb;
+			}
+			
+			if ($entrytype eq 'report'){
+				$date=$year;
+				print 'date=',"$date";
+			}
+		
+		}
+		
+		#---------------------------------------------------------------
+		#条目类型:标准/standard
+		#---------------------------------------------------------------
+		if(1){
+			if ($reference=~m/\[S\/OL\]\./){
+				$entrytype='standard';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[S\/OL\]\.';
+				&bfidentifier;
+				
+				$regexformach='S\/OL\]\.';
+				&bfaddressbook;
+				&afpublisherbookurl;
+			}elsif($reference=~m/\[S\]\./){
+				$entrytype='standard';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[S\]\.';
+				&bfidentifier;
+				
+				$regexformach='S\]\.';
+				&bfaddressbook;
+				
+				&afpublisherbook;
+			}elsif ($reference=~m/\[S\/OL\]\/\//){
+				$entrytype='standard';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[S\/OL\]\/\/';
+				&bfidentifier;
+				
+				$regexformach='S\/OL\]\/\/';
+				&bfaddressinbook;
+			
+				&afpublisherbookurl;
+			}elsif($reference=~m/\[S\]\/\//){
+				$entrytype='standard';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[S\]\/\/';
+				&bfidentifier;
+				
+				$regexformach='S\]\/\/';
+				&bfaddressinbook;
+				
+				&afpublisherbook;
+			}
+			if ($entrytype eq 'standard'){
+				if ($address=~m/\[S\.l\.\]/ or $address=~m/出版地不详/) {#当存在英文的[s.n.]
+					$address=""; 
+				}
+				if ($publisher=~m/\[s\.n\.\]/ or $publisher=~m/出版者不详/) {#当存在英文的[s.n.]
+					$publisher=""; 
+				}
+				$date=$year;
+				$note='standard';
+				print 'date=',"$date";
+				print 'note=',"$note";
+			}
+		
+		}
+		
+		#---------------------------------------------------------------
+		#条目类型:学位论文/thesis
+		#---------------------------------------------------------------
+		if(1){
+			if ($reference=~m/\[D\/OL\]\./){
+				$entrytype='thesis';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[D\/OL\]\.';
+				&bfidentifier;
+				
+				$regexformach='D\/OL\]\.';
+				&bfaddressbook;
+			
+				&afpublisherbookurl;
+			}elsif($reference=~m/\[D\]\./){
+				$entrytype='thesis';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[D\]\.';
+				&bfidentifier;
+				
+				$regexformach='D\]\.';
+				&bfaddressbook;
+				
+				&afpublisherbook;
+			}
+			
+			if ($entrytype eq 'thesis'){
+				if ($address=~m/\[S\.l\.\]/ or $address=~m/出版地不详/) {#当存在英文的[s.n.]
+					$address=""; 
+				}
+				if ($publisher=~m/\[s\.n\.\]/ or $publisher=~m/出版者不详/) {#当存在英文的[s.n.]
+					$publisher=""; 
+				}
+				$date=$year;
+				print 'date=',"$date";
+			}
+		
+		}
+		
+		
+		#---------------------------------------------------------------
+		#条目类型:汇编中析出的文献/incollection 
+		#---------------------------------------------------------------
+		if(1){#\/\/
+			if ($reference=~m/\[G\/OL\]\/\//){
+				$entrytype='incollection';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[G\/OL\]\/\/';
+				&bfidentifier;
+				
+				$regexformach='G\/OL\]\/\/';
+				&bfaddressinbook;
+			
+				&afpublisherbookurl;
+			}elsif($reference=~m/\[G\]\/\//){
+				$entrytype='incollection';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[G\]\/\/';
+				&bfidentifier;
+				
+				$regexformach='G\]\/\/';
+				&bfaddressinbook;
+				
+				&afpublisherbook;
+			}
+			
+			if ($entrytype eq 'incollection'){
+				if ($address=~m/\[S\.l\.\]/ or $address=~m/出版地不详/) {#当存在英文的[s.n.]
+					$address=""; 
+				}
+				if ($publisher=~m/\[s\.n\.\]/ or $publisher=~m/出版者不详/) {#当存在英文的[s.n.]
+					$publisher=""; 
+				}
+				$date=$year;
+			}
+			
+		}
+		
+		
+		#---------------------------------------------------------------
+		#条目类型:汇编/collection 
+		#---------------------------------------------------------------
+		if(1){
+			if ($reference=~m/\[G\/OL\]\./){
+				$entrytype='collection';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[G\/OL\]\.';
+				&bfidentifier;
+				
+				$regexformach='G\/OL\]\.';
+				&bfaddressbook;
+			
+				&afpublisherbookurl;
+			}elsif($reference=~m/\[G\]\./){
+				$entrytype='collection';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[G\]\.';
+				&bfidentifier;
+				
+				$regexformach='G\]\.';
+				&bfaddressbook;
+				
+				&afpublisherbook;
+			}
+			
+			if ($entrytype eq 'collection'){
+				if ($address=~m/\[S\.l\.\]/ or $address=~m/出版地不详/) {#当存在英文的[s.n.]
+					$address=""; 
+				}
+				if ($publisher=~m/\[s\.n\.\]/ or $publisher=~m/出版者不详/) {#当存在英文的[s.n.]
+					$publisher=""; 
+				}
+				$date=$year;
+				print 'date=',"$date";
+			}
+		}
+		
+		
+		#---------------------------------------------------------------
+		#条目类型:专利/patent
+		#---------------------------------------------------------------
+		if(1){
+			if ($reference=~m/\[P\/OL\]\./){
+				$entrytype='patent';
+				print "this entry's type is: $entrytype with url\n";
+				$regexformach='\[P\/OL\]\.';
+				&bfidentifier;
+			}elsif($reference=~m/\[P\]\./){
+				$entrytype='patent';
+				print "this entry's type is: $entrytype \n";
+				$regexformach='\[P\]\.';
+				&bfidentifier;
+			}
+			
+			if($entrytype eq 'patent'){
+				($postitle)=($reference=~m/$regexformach\s*(.*)/);
+				print 'postitle=',$postitle,"\n";
+				$titlenumber=$title;
+				if($titlenumber=~m/:\s*\d.*/){
+					($title,$number)=($titlenumber=~m/(.*):\s*(\d.*)/);
+					print 'title  =',$title,"\n";
+					print 'number =',$number,"\n";
+				}
+				
+				if($postitle=~m/\[.*\]/ and $reference=~m/\[P\/OL\]\./){
+					($date,$urldate,$posurl)=($postitle=~/(.*)\s*\[(.*)\]\.\s*(.*)/);
+					print 'date=',$date,"\n";
+					print 'urldate  =',$urldate,"\n";
+					print 'posurl   =',$posurl,"\n";
+					if($posurl=~m/DOI/i){#匹配存在doi的话
+						($url,$doi)=($posurl=~m/(.*)DOI:(.*)\./i);
+						print 'url=',"$url \n";
+						print 'doi=',"$doi \n";
+					}else{
+						$url=$posurl;
+						print 'url   =',"$url \n";
+					}
+				}else{
+					$posurl=$postitle;
+					if($posurl=~m/DOI/i){#匹配存在doi的话
+						($date,$doi)=($posurl=~m/(.*)DOI:(.*)\./i);
+						print 'date=',"$date \n";
+						print 'doi =',"$doi \n";
+					}else{
+						$date=$posurl;
+						print 'date   =',"$date \n";
+					}
+				}
+			}
+		}
+		
+		
+		#---------------------------------------------------------------
+		#条目类型:电子资源/online
+		#---------------------------------------------------------------
+		if(1){
+			if ($reference=~m/\[EB\/OL\]\./){#匹配[EB/OL]判断为online类型
+				$entrytype='online';
+				print "this entry's type is: $entrytype \n";
+				
+				$regexformach='\[EB\/OL\]\.';
+				&bfidentifier;
+				
+				($postitle)=($reference=~m/$regexformach\s*(.*)/);
+				print 'postitle=',$postitle,"\n";
+				
+				if($postitle=~m/\(.*\)/ and $postitle=~m/\[.*\]/){#存在更新日期和引用日期
+					($eventdate,$urldate,$posurl)=($postitle=~/\s*\((.*)\)\s*\[(.*)\]\.\s*(.*)/);
+				}elsif($postitle=~m/\(.*\)/ and $postitle!~m/\[.*\]/){#存在更新日期但无引用日期
+					($eventdate,$posurl)=($postitle=~/\s*\((.*)\)\.\s*(.*)/);
+				}elsif($postitle!~m/\(.*\)/ and $postitle=~m/\[.*\]/){#存在引用日期但无更新日期
+					($urldate,$posurl)=($postitle=~/\s*\[(.*)\]\.\s*(.*)/);
+				}else{
+					($posurl)=($postitle=~/\s*(.*)/);
+				}
+				print 'eventdate=',$eventdate,"\n";
+				print 'urldate  =',$urldate,"\n";
+				print 'posurl   =',$posurl,"\n";
+				
+				if($posurl=~m/DOI/i){#匹配存在doi的话
+					($url,$doi)=($posurl=~m/(.*)DOI:(.*)\./i);
+					print 'url=',"$url \n";
+					print 'doi=',"$doi \n";
+				}else{
+					$url=$posurl;
+					print 'url   =',"$url \n";
+				}
+			}
+		}
+		
+		#---------------------------------------------------------------
+		#条目类型:专著/book
+		#---------------------------------------------------------------
+		if(1){
+		if ($reference=~m/\[M\]\./){#匹配[M]判断为book类型
+			print "this entry's type is: book \n";
+			$entrytype='book';
+			
+			$regexformach='\[M\]\.';
+			&bfidentifier;
+					
+			$regexformach='M\]\.';
+			&bfaddressbook;
+			
+			&afpublisherbook;
+			
+			if ($address=~m/\[S\.l\.\]/ or $address=~m/出版地不详/) {#当存在英文的[s.n.]
+				$address=""; 
+			}
+			if ($publisher=~m/\[s\.n\.\]/ or $publisher=~m/出版者不详/) {#当存在英文的[s.n.]
+				$publisher=""; 
+			}
+			$date=$year;
+		}
+		}
+		
+		#---------------------------------------------------------------
+		#条目类型:专著但存在网址/book with url  
+		#---------------------------------------------------------------
+		if(1){
+		if ($reference=~m/\[M\/OL\]\./){ 
+			print "this entry's type is: book with url\n";
+			$entrytype='book';
+			
+			$regexformach='\[M\/OL\]\.';
+			&bfidentifier;
+			
+			$regexformach='M\/OL\]\.';
+			&bfaddressbook;
+		
+			&afpublisherbookurl;
+
+			
+			if ($address=~m/\[S\.l\.\]/ or $address=~m/出版地不详/) {#当存在英文的[s.n.]
+				$address=""; 
+			}
+			if ($publisher=~m/\[s\.n\.\]/ or $publisher=~m/出版者不详/) {#当存在英文的[s.n.]
+				$publisher=""; 
+			}
+			$date=$year;
+		}
+		}
+		
+			
+		#---------------------------------------------------------------
+		#条目类型:专著中析出文献/inbook
+		#---------------------------------------------------------------
+		if(1){
+		if ($reference=~m/\[M\]\/\//){#匹配[M]//判断为inbook类型
+			print "this entry's type is: inbook \n";
+			$entrytype='inbook';
+			
+			$regexformach='\[M\]\/\/';
+			&bfidentifier;
+					
+			$regexformach='M\]\/\/';
+			&bfaddressinbook;
+			
+			&afpublisherbook;#出版社及之后的信息inbook/book一样的
+
+			
+			if ($address=~m/\[S\.l\.\]/ or $address=~m/出版地不详/) {#当存在英文的[s.n.]
+				$address=""; 
+			}
+			if ($publisher=~m/\[s\.n\.\]/ or $publisher=~m/出版者不详/) {#当存在英文的[s.n.]
+				$publisher=""; 
+			}
+			$date=$year;
+		}
+		}
+		
+
+		#---------------------------------------------------------------
+		#条目类型:专著中析出文献但存在网址/inbook with url
+		#---------------------------------------------------------------
+		if(1){
+			if ($reference=~m/\[M\/OL\]\/\//){#匹配[M]//判断为inbook类型
+			print "this entry's type is: inbook \n";
+			$entrytype='inbook';
+			
+			
+			$regexformach='\[M\/OL\]\/\/';
+			&bfidentifier;
+					
+			$regexformach='M\/OL\]\/\/';
+			&bfaddressinbook;
+			
+			&afpublisherbookurl;#出版社及之后的信息inbook/book一样的
+
+			
+			if ($address=~m/\[S\.l\.\]/ or $address=~m/出版地不详/) {#当存在英文的[s.n.]
+				$address=""; 
+			}
+			if ($publisher=~m/\[s\.n\.\]/ or $publisher=~m/出版者不详/) {#当存在英文的[s.n.]
+				$publisher=""; 
+			}
+			$date=$year;
+		}
+		}
+		
+			
+		#---------------------------------------------------------------
+		#输出到bib文件中
+		#---------------------------------------------------------------
+		if(1){
+			if($date=~m/-\d{4}/){#存在enddate的情况下,将中间的连字符转化成斜杠
+				print 'date=',$date,"\n";
+				($datetempa,$datetempb)=($date=~m/(.*)-(\d{4}.*)/);
+				$date=$datetempa.'/'.$datetempb;
+				print 'date=',$date,"\n";
+			}
+		
+			if($url=~m/.*\.$/){
+				$urlplusdot=$url;
+				($url)=($urlplusdot=~m/(.*)\.$/);#去掉处于条目末尾的url地址后的点
+			}
+			#最后输出
+			print "\n";
+			#print '@',"$entrytype",'{',"ref-$nline-$sn",',',"\n";
+			print '@',"$entrytype",'{',"$author$date",',',"\n";
+			$author&& print 'author    = {',$author,'},',"\n";
+			$title&& print 'title     = {',$title,'},',"\n";
+			$journal&& print 'journal   = {',$journal,'},',"\n";
+			$translator&& print 'translator= {',$translator,'},',"\n";
+			$bookauthor&& print 'bookauthor= {',$bookauthor,'},',"\n";
+			$booktitle&& print 'booktitle = {',$booktitle,'},',"\n";
+			$version&& print 'version   = {',$version,'},',"\n";
+			$address&& print 'address   = {',$address,'},',"\n";
+			$publisher&& print 'publisher = {',$publisher,'},',"\n";
+			$type&& print 'type = {',$type,'},',"\n";
+			$date&& print 'date      = {',$date,'},',"\n";
+			$volume&& print 'volume      = {',$volume,'},',"\n";
+			$number&& print 'number      = {',$number,'},',"\n";
+			$pages&& print 'pages     = {',$pages,'},',"\n";
+			$eventdate&& print 'eventdate   = {',$eventdate,'},',"\n";
+			$urldate&& print 'urldate   = {',$urldate,'},',"\n";
+			$url&& print 'url       = {',$url,'},',"\n";
+			$doi&& print 'doi       = {',$doi,'},',"\n";
+			$note&& print 'note       = {',$note,'},',"\n";
+			print '}',"\n";
+			print 'authorlabel=',$authorlabel,"\n";
+		
+				
+			#print FHW "\n@","$entrytype",'{',"ref-$nline-$sn-$authorlabel",',',"\n";
+			print FHW "\n@","$entrytype",'{',"$authorlabel$date",',',"\n";
+			$author&& print FHW 'author    = {',$author,'},',"\n";
+			$title&& print FHW 'title     = {',$title,'},',"\n";
+			$journal&& print FHW 'journal   = {',$journal,'},',"\n";
+			$translator&& print FHW 'translator= {',$translator,'},',"\n";
+			$bookauthor&& print FHW 'bookauthor= {',$bookauthor,'},',"\n";
+			$booktitle&& print FHW 'booktitle = {',$booktitle,'},',"\n";
+			$version&& print FHW 'version   = {',$version,'},',"\n";
+			$address&& print FHW 'address   = {',$address,'},',"\n";
+			$publisher&& print FHW 'publisher = {',$publisher,'},',"\n";
+			$type&& print FHW 'type = {',$type,'},',"\n";
+			$date&& print FHW 'date      = {',$date,'},',"\n";
+			$volume&& print FHW 'volume      = {',$volume,'},',"\n";
+			$number&& print FHW 'number      = {',$number,'},',"\n";
+			$pages&& print FHW 'pages     = {',$pages,'},',"\n";
+			$eventdate&& print FHW 'eventdate   = {',$eventdate,'},',"\n";
+			$urldate&& print FHW 'urldate   = {',$urldate,'},',"\n";
+			$url&& print FHW 'url       = {',$url,'},',"\n";
+			$doi&& print FHW 'doi       = {',$doi,'},',"\n";
+			$note&& print FHW 'note       = {',$note,'},',"\n";
+			print FHW '}',"\n";
+		}
+	}
+	
+	
+	print "\n";
+	if($nline>=$ne){last;} #先跳过几行进行,配合后面的last进行当行测试
+}
+
+	sub bfidentifier{#bf表示before,标识符前所有的类型都一样
+		#$regexpformach=@_;
+		#print '@_=', at _,"\n";
+		#print 'regexpformach=',"$regexpformach \n";
+		#标识符之前很容易匹配三个内容,序号,作者和标题
+		if($reference=~m/.*\D\.\s\D.*$regexformach/){#匹配存在作者后的点的话,同时点号周围不是数字,有时标题中可能出现1.1这样的信息
+			($sn , $author , $title)=($reference=~m/\[(\d+)\]\s*(.*)\.\s(.*)$regexformach/);
+			print 'sn    =',"$sn \n";
+			print 'author=',"$author \n";#作者多个姓名还需要处理,还要注意有前后缀的情况
+			print 'title =',"$title \n";
+			if($author=~m/等/){
+				$author=~s/等/others/;#将等换成others
+			}else{
+				$author=~s/,\s*$//;#将最后一个逗号去掉
+			}
+			if($author=~m/et\sal/){
+				$author=~s/et\sal/others/;#将et al.换成others
+			}else{
+				$author=~s/,\s*$//;#将最后一个逗号去掉
+			}
+			while($author=~m/,/){
+				$author=~s/,/ and /;#将逗号换成and
+			}
+			#当“等”直接与作者相连时,需要在others前面增加一个and
+			if($author=~m/others/){#若存在other是且其前面没有and时
+				if ($author=~m/and\s*others/){}
+				else{
+					$author=~s/others/ and others/;
+				}
+			}
+			print 'author=',"$author \n";
+		}else{#不存在作者的话\[M\]\/\/
+			($sn , $title)=($reference=~m/\[(\d+)\]\s*(.*)$regexformach/);#标识符之前很容易匹配三个内容,序号,作者和标题
+			print 'sn    =',"$sn \n";
+			print 'title =',"$title \n";
+		}
+		
+		#进一步处理责任者的姓名,主要针对英文名需要有一些符号进行区分姓,名,前缀和后缀。
+		@names=split('and',$author);
+		print 'names=', at names,"\n";
+		$author="";
+		$j=0;
+		foreach $name(@names){#一个姓名一个姓名处理
+			
+			$j=$j+1;
+			#print $name,"\n";
+			@nameparts=split(' ',$name);
+			#print 'nameparts=', at nameparts,"\n";
+			
+			$org=0;
+			for($k=0;$k<@nameparts;$k++){
+			if(@nameparts[$k]=~m/.{2,}/ and @nameparts[$k]!~m/\s*von\s*/i and @nameparts[$k]!~m/\s*jr\s*/i){
+			#当分解的单作者的各个部分,存在两个以上为2个字符以上的情况,说明不是一般的姓名而是机构作者
+			#这个判断是对的,因为国标规定要求缩写的,否则就是不是国标了,对于不标准的情形请输出后手动处理即去掉作者外包围的花括号。
+				$org=$org+1;
+				print 'org=',"$org\n";
+			}
+			}
+			
+			if(@nameparts>1){
+				if(@nameparts[0]=~m/\s*von\s*/i){#确定姓的位置
+					$family=1;
+					@nameparts[1]=@nameparts[1].',';
+				}else{
+					$family=0;
+					@nameparts[0]=@nameparts[0].',';
+				}
+				if(@nameparts[-1]=~m/\s*jr\s*/i){#确定后缀的位置
+					@nameparts[-1]=@nameparts[-1].'.,';
+					$given=@nameparts-2;
+					$suffix=1;
+				}else{
+					$suffix=0;
+					$given=@nameparts-1;
+				}
+				print 'family=',$family,"\n";
+				print 'given=',$given,"\n";
+				print 'suffix=',$suffix,"\n";
+				print 'familyname=', at nameparts[$family],"\n";
+				
+				$namefmt="";
+				for($i=0;$i<=$family;$i++){
+					$namefmt=$namefmt. at nameparts[$i].' ';
+					print $i,$family,$namefmt,"\n";
+				}
+				if($suffix){
+					$namefmt=$namefmt. at nameparts[-1].' ';
+				}
+				for($i=$family+1;$i<=$given;$i++){
+					$namefmt=$namefmt. at nameparts[$i].' ';
+					print $i,$family,$namefmt,"\n";
+				}
+			}else{
+				$namefmt=$name;
+			}
+			if($org > 1){#当是机构作者时
+				$namefmt='{'.$name.'}';
+			}
+			print 'namefmt=',"$namefmt \n";
+			
+			if($j==1){#把姓名用and连接起来
+				$author=$namefmt;
+			}else{
+				$author=$author.' and '.$namefmt;
+			}
+			
+			if($j==1){#根据第一个作者构建authorlabel
+				if($org > 1){#机构作者取各单词的首字母
+					$authorlabel='';
+					for($k=0;$k<@nameparts;$k++){
+						($strtmp)=($nameparts[$k]=~/^(.)/);
+						$authorlabel=$authorlabel.$strtmp;
+					}
+				}else{#姓名则仅取作者姓
+					($authorlabel)=$nameparts[$family];
+					if($authorlabel=~m/,$/){$authorlabel=~s/,$//;}#去掉最后的逗号
+				}
+			}
+		}
+		while($author=~m/\s{2,}/){
+				$author=~s/\s{2,}/ /;#将多余的空格去掉
+			}
+		while($author=~m/\.{2,}/){
+				$author=~s/\.{2,}/\./;#将多余的点去掉
+			}
+		print 'author=',"$author\n";
+	}
+
+	
+	sub bfaddressbook{#bf表示before,出版者前book和inbook不一样
+	#对于book类型,必然存在出版地和出版者信息,以此为根据展开
+		print 'sub:bfaddressbook ',"\n";
+		if($reference!~m/$regexformach\s*[^:]+:\s\D{1,}.*/){#如果不存在出版地和出版者信息
+			($pospublisher)=($reference=~m/$regexformach\s*(.*)/);
+			print 'pospublisher=',"$pospublisher \n";
+		}else{
+			($preaddress, $pospublisher)=($reference=~m/$regexformach\s*([^:]+):\s(\D{1,}.*)/);#标识符之后根据第一个冒号分为包括地址的信息和包括出版者的信息两部分
+			print 'preaddress  =',"$preaddress \n";
+			print 'pospublisher=',"$pospublisher \n";
+			
+			#处理出版地及其前面的信息
+			if ($preaddress=~m/.*\[S\.l\.\].*/) {#当存在英文的[S.l.],英文的一般不存在译者,所以下面处理比较简单
+				$preaddress=~s/\[S\.l\.\]/\[S-l-\]/; #先将[S.l.]换成[S-l-]然后换回来
+			}
+				if ($preaddress=~m/.*\d.*\.\s*.*/){#匹配存在数字版本的话
+					($preversion, $version, $address)=($preaddress=~m/(.*)(\d)[^\.]*\.\s*(.*)/);
+					print 'preversion  =',"$preversion \n";
+					print 'version     =',"$version \n";
+					print 'address     =',"$address \n";
+					if($preversion=~m/.*\..*/){#如果存在译者等信息
+						($translator)=($preversion=~m/(.*)\..*/);
+						print 'translator  =',"$translator \n";#作者多个姓名还需要处理,还有译这个标识
+					}
+				}else {#不存在数字版本的话
+					if($preaddress=~m/.*\.\s+.*/){#存在点加空格,表示存在其他作者信息,区别点在末尾但无空格
+					($preversion,$address)=($preaddress=~m/(.*)\.\s*(.*)/);
+					print 'preversion  =',"$preversion \n";
+					print 'address     =',"$address \n";
+					$translator=$preversion;
+					print 'translator  =',"$translator \n";
+					}else{
+					$address=$preaddress;
+					print 'address     =',"$address \n";
+					}
+				}
+				
+				if($translator=~m/译/){#当译者真实存在
+					$translator=~s/,\s*译//;#将译去掉
+					if($translator=~m/等/){
+						$translator=~s/等/others/;#将等换成others
+					}else{
+						$translator=~s/,\s*$//;#将最后一个逗号去掉
+					}
+					while($translator=~m/,/){
+						$translator=~s/,/ and /;#将逗号换成and
+					}
+					print 'translator  =',"$translator \n";
+				}else {#当译者不存在,那么translator中信息可能是非数字的版本信息
+					unless($version) {#除非version没有信息
+					$version=$translator;
+					$translator="";
+					}else{
+					print "version is already exisit!\n";
+					print 'version=',$version,"\n";
+					print 'translator=',$translator,"\n";
+					}
+				}
+				
+			if ($address=~m/.*\[S-l-\].*/) {#当存在英文的[S-l-][S.l.]
+				$address=~s/\[S-l-\]/\[S\.l\.\]/; #将[S-l-]换回[S.l.]
+			}
+		}
+	}
+
+	
+	sub bfaddressinbook{#bf表示before,出版者前book和inbook不一样
+		($postitle)=($reference=~m/$regexformach\s*(.*)/);
+		print 'postitle=',$postitle,"\n";
+		if($postitle=~m/^[^:\.]+:[^:\.]+\./){#当存在析出源第一项中出现:时
+			$postitle=~s/:/colon/;#先将该冒号换成colon
+			print 'postitle=',$postitle,"\n";
+		}
+		#对于inbook类型,必然存在出版地和出版者信息,以此为根据展开
+		($preaddress, $pospublisher)=($postitle=~m/\s*(.*):\s(\D.*)/);
+		#($preaddress, $pospublisher)=($postitle=~m/\s*([^:]+):\s(\D.*)/);
+		#标识符之后根据第一个冒号分为包括地址的信息和包括出版者的信息两部分
+		print 'preaddress  =',"$preaddress \n";
+		print 'pospublisher=',"$pospublisher \n";
+		
+		#处理出版地及其前面的信息
+		if ($preaddress=~m/.*\[S\.l\.\].*/) {#当存在英文的[S.l.],英文的一般不存在译者,所以下面处理比较简单
+			$preaddress=~s/\[S\.l\.\]/\[S-l-\]/; #先将[S.l.]换成[S-l-]然后换回来
+		}
+			if ($preaddress=~m/.*\d.*\.\s+.*/ and ($preaddress=~m/.*th\sed.*/ or $preaddress=~m/.*版.*/)){#匹配存在数字版本的话
+				($preversion, $version, $address)=($preaddress=~m/(.*)(\d)[^\.]*\.\s+(.*)/);
+				print 'preversion  =',"$preversion \n";
+				print 'version     =',"$version \n";
+				print 'address     =',"$address \n";
+				if($preversion=~m/.*\.\s+.*/){#如果存在译者等信息
+					($translator)=($preversion=~m/(.*)\.\s+.*/);
+					print 'translator  =',"$translator \n";#作者多个姓名还需要处理,还有译这个标识
+				}
+			}else {#不存在数字版本的话
+				if($preaddress=~m/.*\.\s+.*/){#存在点加空格,表示存在其他作者信息,区别点在末尾但无空格
+					($preversion,$address)=($preaddress=~m/(.*)\.\s+(.*)/);
+					print 'preversion  =',"$preversion \n";
+					print 'address     =',"$address \n";
+					if($preversion=~m/.*\.\s+.*/){#中间还存在点加空格
+						($bookauthor,$booktitle)=($preversion=~m/(.*)\.\s+(.*)/);
+						
+						if($bookauthor=~m/等/){
+							$bookauthor=~s/等/others/;#将等换成others
+						}else{
+							$bookauthor=~s/,\s*$//;#将最后一个逗号去掉
+						}
+						if($bookauthor=~m/et\sal/){
+							$bookauthor=~s/et\sal/others/;#将et al.换成others
+						}else{
+							$bookauthor=~s/,\s*$//;#将最后一个逗号去掉
+						}
+						while($bookauthor=~m/,/){
+							$bookauthor=~s/,/ and /;#将逗号换成and
+						}
+						print 'bookauthor=',"$bookauthor \n";
+					}else{
+						$booktitle=$preversion;
+					}
+				}else{
+				$address=$preaddress;
+				print 'address     =',"$address \n";
+				}
+			}
+			
+		if ($address=~m/.*\[S-l-\].*/) {#当存在英文的[S-l-][S.l.]
+			$address=~s/\[S-l-\]/\[S\.l\.\]/; #将[S-l-]换回[S.l.]
+		}
+		if ($booktitle=~m/.*colon.*/) {#当存在colon
+			$booktitle=~s/colon/:/; #将colon换回:
+		}
+		
+		#进一步处理责任者的姓名,主要针对英文名需要有一些符号进行区分姓,名,前缀和后缀。
+		@names=split('and',$bookauthor);
+		print 'names=', at names,"\n";
+		$bookauthor="";
+		$j=0;
+		foreach $name(@names){
+			$j=$j+1;
+			#print $name,"\n";
+			@nameparts=split(' ',$name);
+			#print 'nameparts=', at nameparts,"\n";
+			
+			$org=0;
+			for($k=0;$k<@nameparts;$k++){
+			if(@nameparts[$k]=~m/.{2,}/ and @nameparts[$k]!~m/\s*von\s*/i and @nameparts[$k]!~m/\s*jr\s*/i){
+			#当分解的单作者的各个部分,存在两个以上为2个字符以上的情况,说明不是一般的姓名而是机构作者
+				$org=$org+1;
+				print 'org=',"$org\n";
+			}
+			}
+			
+			if(@nameparts>1){
+				if(@nameparts[0]=~m/\s*von\s*/i){#确定姓的位置
+					$family=1;
+					@nameparts[1]=@nameparts[1].',';
+				}else{
+					$family=0;
+					@nameparts[0]=@nameparts[0].',';
+				}
+				if(@nameparts[-1]=~m/\s*jr\s*/i){#确定后缀的位置
+					@nameparts[-1]=@nameparts[-1].'.,';
+					$given=@nameparts-2;
+					$suffix=1;
+				}else{
+					$suffix=0;
+					$given=@nameparts-1;
+				}
+				#print 'family=',$family,"\n";
+				#print 'given=',$given,"\n";
+				#print 'suffix=',$suffix,"\n";
+				
+				$namefmt="";
+				for($i=0;$i<=$family;$i++){
+					$namefmt=$namefmt. at nameparts[$i].' ';
+					#print $i,$family,$namefmt,"\n";
+				}
+				if($suffix){
+					$namefmt=$namefmt. at nameparts[-1].' ';
+				}
+				for($i=$family+1;$i<=$given;$i++){
+					$namefmt=$namefmt. at nameparts[$i].' ';
+				}
+			}else{
+				$namefmt=$name;
+			}
+			if($org > 1){#当是机构作者时
+				$namefmt='{'.$name.'}';
+			}
+			#print 'namefmt=',"$namefmt \n";
+			
+			if($j==1){
+				$bookauthor=$namefmt;
+			}else{
+				$bookauthor=$bookauthor.' and '.$namefmt;
+			}
+		}
+		while($bookauthor=~m/\s{2,}/){
+				$bookauthor=~s/\s{2,}/ /;#将多余的空格去掉
+			}
+		while($bookauthor=~m/\.{2,}/){
+				$bookauthor=~s/\.{2,}/\./;#将多余的点去掉
+			}
+		print 'bookauthor=',"$bookauthor\n";
+	}
+	
+
+	sub afpublisherbook{#af表示after,出版者后book和inbook一样,但如果存在url则不同
+	    #处理出版者及其后面的信息
+		if ($pospublisher=~m/.*\[s\.n\.\].*/) {#当存在英文的[s.n.]
+			$pospublisher=~s/\[s\.n\.\]/\[s-n-\]/; #先将[s.n.]换成[s-n-]然后换回来
+		}
+			if ($pospublisher=~m/.*,\s*\d{4}\S+/){#匹配存在年份的话
+				($publisher, $year, $posyear)=($pospublisher=~m/(.*),\s*(\d{4})(.*)/);
+				print 'publisher=',"$publisher \n";
+				print 'year     =',"$year \n";
+				print 'posyear  =',"$posyear \n";
+				if($posyear=~m/^:/){#匹配存在页码前面的冒号的话
+					($pages, $pospages)=($posyear=~m/^:([^\.]+)\.(.*)/);
+					print 'pages   =',"$pages \n";
+					print 'pospages=',"$pospages \n";
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+					($doi)=($pospages=~m/DOI:(.*)\./i);
+					print 'doi=',"$doi \n";
+					}
+				}else{#不存在页码的话
+					if($posyear=~m/DOI/i){#匹配存在doi的话
+					($doi)=($posyear=~m/DOI:(.*)\./i);
+					print 'doi=',"$doi \n";
+					}
+				}
+			}else{#不存在年份,匹配一下是否存在冒号和页码
+				if($pospublisher=~m/.*[^DOI]:.*/i){#当存在不是doi后面的冒号时,说明有页码
+					($publisher, $pages, $pospages)=($pospublisher=~m/([^:]*):([^\.]*)\.(.*)/);
+					print 'publisher=',"$publisher \n";
+					print 'pages    =',"$pages \n";
+					print 'pospages =',"$pospages \n";
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+					($doi)=($pospages=~m/DOI:(.*)\./i);
+					print 'doi=',"$doi \n";
+					}
+				}else{#没有页码冒号以点作为出版者后的分隔点
+					($publisher, $pospages)=($pospublisher=~m/([^\.]*)\.(.*)/);
+					print 'publisher=',"$publisher \n";
+					print 'pospages =',"$pospages \n";
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+					($doi)=($pospages=~m/DOI:(.*)\./i);
+					print 'doi=',"$doi \n";
+					}
+				}
+			}
+		if ($publisher=~m/.*\[s-n-\].*/) {#当存在英文的[s-n-]
+			$publisher=~s/\[s-n-\]/\[s\.n\.\]/; #将[s-n-]换回[s.n.]
+		}
+	}
+	
+	
+	sub afpublisherbookurl{#af表示after,出版者后book和inbook一样,但如果存在url则不同
+			#处理出版者及其后面的信息
+		if ($pospublisher=~m/.*\[s\.n\.\].*/) {#当存在英文的[s.n.]
+			$pospublisher=~s/\[s\.n\.\]/\[s-n-\]/; #先将[s.n.]换成[s-n-]然后换回来
+		}
+			if ($pospublisher=~m/.*,\s*\d{4}[^\d-]/){#匹配存在年份的话,4个数字后面跟着不能是数字和连字符-
+				($publisher, $year, $posyear)=($pospublisher=~m/(.*),\s*(\d{4})(.*)/);
+				print 'publisher=',"$publisher \n";
+				print 'year     =',"$year \n";
+				print 'posyear  =',"$posyear \n";
+				if($posyear=~m/^:/){#匹配存在页码前面的冒号的话
+					($pages, $pospages)=($posyear=~m/^:([^\.]+)\.(.*)/);
+					print 'pages   =',"$pages \n";
+					print 'pospages=',"$pospages \n";
+					if($pages=~m/\[.*\]/){
+						($pagesa, $urldate)=($pages=~m/(.*)\[(.*)\]/);
+						$pages=$pagesa;
+						print 'urldate=',"$urldate \n";
+						print 'pages=',"$pages \n";
+					}
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+						($url, $doi)=($pospages=~m/(.*)\.\s*DOI:(.*)\./i);
+						print 'url=',"$url \n";
+						print 'doi=',"$doi \n";
+					}else{
+						($url)=($pospages=~m/(.*)\./i);
+						print 'url=',"$url \n";
+					}
+				}
+				else{#不存在页码的话
+					if($posyear=~m/\[.*\]/){
+						($urldate,$pospages)=($posyear=~m/.*\[(.*)\]\.(.*)/);
+						print 'urldate=',"$urldate \n";
+						print 'pospages=',"$pospages \n";
+					}
+					else{#不存在页码,又不存在引用日期的话,那么会有一个点和空格
+						($pospages)=($posyear=~m/.*\s(.*)/);
+						print 'pospages=',"$pospages \n";
+					}
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+						($url, $doi)=($pospages=~m/(.*)\.\s*DOI:(.*)\./i);
+						print 'url=',"$url \n";
+						print 'doi=',"$doi \n";
+					}else{
+						($url)=($pospages=~m/(.*)\./i);
+						print 'url=',"$url \n";
+					}
+				}
+			}else{#不存在年份,匹配一下是否存在冒号和页码
+				if($pospublisher=~m/.*[^DOIhttp]:.*/i){#当存在不是doi或http后面的冒号时,说明有页码
+					($publisher, $pages, $pospages)=($pospublisher=~m/([^:]*):([^\.]*)\.(.*)/);
+					print 'publisher=',"$publisher \n";
+					print 'pages    =',"$pages \n";
+					print 'pospages =',"$pospages \n";
+					if($pages=~m/\[.*\]/){
+						($pagesa, $urldate)=($pages=~m/(.*)\[(.*)\]/);
+						$pages=$pagesa;
+						print 'urldate=',"$urldate \n";
+						print 'pages=',"$pages \n";
+					}
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+						($url, $doi)=($pospages=~m/(.*)\.\s*DOI:(.*)\./i);
+						print 'url=',"$url \n";
+						print 'doi=',"$doi \n";
+					}else{
+						($url)=($pospages=~m/(.*)\./i);
+						print 'url=',"$url \n";
+					}
+				}else{#没有页码冒号以点作为出版者后的分隔点
+					($publisher, $pospages)=($pospublisher=~m/([^\.]*)\.(.*)/);
+					print 'publisher=',"$publisher \n";
+					print 'pospages =',"$pospages \n";
+					if($publisher=~m/\[.*\]/){
+						($publishera, $urldate)=($publisher=~m/(.*)\[(.*)\]/);
+						$publisher=$publishera;
+						print 'urldate=',"$urldate \n";
+						print 'publisher=',"$publisher \n";
+					}
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+						($url, $doi)=($pospages=~m/(.*)\.\s*DOI:(.*)\./i);
+						print 'url=',"$url \n";
+						print 'doi=',"$doi \n";
+					}else{
+						($url)=($pospages=~m/(.*)\./i);
+						print 'url=',"$url \n";
+					}
+				}
+			}
+		if ($publisher=~m/.*\[s-n-\].*/) {#当存在英文的[s-n-]
+			$publisher=~s/\[s-n-\]/\[s\.n\.\]/; #将[s-n-]换回[s.n.]
+		}
+	}
+
+
+	sub afpublisherbookb{#af表示after,出版者后book和inbook一样,但如果存在url则不同
+	    #处理出版者及其后面的信息
+		if ($pospublisher=~m/.*\[s\.n\.\].*/) {#当存在英文的[s.n.]
+			$pospublisher=~s/\[s\.n\.\]/\[s-n-\]/; #先将[s.n.]换成[s-n-]然后换回来
+		}
+			if ($pospublisher=~m/.*[\.\s,]*\d{4}[\D\S]+/){#匹配存在年份的话,年份前面没有逗号+空格
+				($publisher, $year, $posyear)=($pospublisher=~m/(.*)[\.\s,]*(\d{4})([\D\S].*)/);
+				print 'publisher=',"$publisher \n";
+				if($publisher=~m/[,\s]+$/){$publisher=~s/[,\s]+$//;}#去掉最后的逗号
+				unless($address){#当没有出版地时,也没有必要存在
+					$version=$publisher;
+					$publisher='';
+				}
+				print 'year     =',"$year \n";
+				print 'posyear  =',"$posyear \n";
+				if($posyear=~m/^:/){#匹配存在页码前面的冒号的话
+					($pages, $pospages)=($posyear=~m/^:([^\.]+)\.(.*)/);
+					print 'pages   =',"$pages \n";
+					print 'pospages=',"$pospages \n";
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+					($doi)=($pospages=~m/DOI:(.*)\./i);
+					print 'doi=',"$doi \n";
+					}
+				}else{#不存在页码的话
+					if($posyear=~m/DOI/i){#匹配存在doi的话
+					($doi)=($posyear=~m/DOI:(.*)\./i);
+					print 'doi=',"$doi \n";
+					}
+				}
+			}else{#不存在年份,匹配一下是否存在冒号和页码
+				if($pospublisher=~m/.*[^DOI]:.*/i){#当存在不是doi后面的冒号时,说明有页码
+					($publisher, $pages, $pospages)=($pospublisher=~m/([^:]*):([^\.]*)\.(.*)/);
+					print 'publisher=',"$publisher \n";
+					print 'pages    =',"$pages \n";
+					print 'pospages =',"$pospages \n";
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+					($doi)=($pospages=~m/DOI:(.*)\./i);
+					print 'doi=',"$doi \n";
+					}
+				}else{#没有页码冒号以点作为出版者后的分隔点
+					($publisher, $pospages)=($pospublisher=~m/([^\.]*)\.(.*)/);
+					print 'publisher=',"$publisher \n";
+					print 'pospages =',"$pospages \n";
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+					($doi)=($pospages=~m/DOI:(.*)\./i);
+					print 'doi=',"$doi \n";
+					}
+				}
+				if($publisher=~m/,$/){$publisher=~s/,$//;}#去掉最后的逗号
+				unless($address){#当没有出版地时,也没有必要存在
+						$type=$publisher;
+						$publisher='';
+				}
+			}
+		if ($publisher=~m/.*\[s-n-\].*/) {#当存在英文的[s-n-]
+			$publisher=~s/\[s-n-\]/\[s\.n\.\]/; #将[s-n-]换回[s.n.]
+		}
+	}
+	
+	
+		
+	sub afpublisherbookurlb{#af表示after,出版者后book和inbook一样,但如果存在url则不同
+			#处理出版者及其后面的信息
+		if ($pospublisher=~m/.*\[s\.n\.\].*/) {#当存在英文的[s.n.]
+			$pospublisher=~s/\[s\.n\.\]/\[s-n-\]/; #先将[s.n.]换成[s-n-]然后换回来
+		}
+			if ($pospublisher=~m/.*[\.\s,]*\d{4}[^\d-]/){#匹配存在年份的话,4个数字后面跟着不能是数字和连字符-
+				($publisher, $year, $posyear)=($pospublisher=~m/(.*)[\.\s,]*(\d{4})([^\d-].*)/);
+				print 'publisher=',"$publisher \n";
+				print 'year     =',"$year \n";
+				print 'posyear  =',"$posyear \n";
+				if($publisher=~m/,$/){$publisher=~s/,$//;}#去掉最后的逗号
+				unless($address){#当没有出版地时,也没有必要存在
+					$version=$publisher;
+					$publisher='';
+				}
+				if($posyear=~m/^:/){#匹配存在页码前面的冒号的话
+					($pages, $pospages)=($posyear=~m/^:([^\.]+)\.(.*)/);
+					print 'pages   =',"$pages \n";
+					print 'pospages=',"$pospages \n";
+					if($pages=~m/\[.*\]/){
+						($pagesa, $urldate)=($pages=~m/(.*)\[(.*)\]/);
+						$pages=$pagesa;
+						print 'urldate=',"$urldate \n";
+						print 'pages=',"$pages \n";
+					}
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+						($url, $doi)=($pospages=~m/(.*)\.\s*DOI:(.*)\./i);
+						print 'url=',"$url \n";
+						print 'doi=',"$doi \n";
+					}else{
+						($url)=($pospages=~m/(.*)\./i);
+						print 'url=',"$url \n";
+					}
+				}
+				else{#不存在页码的话
+					if($posyear=~m/\[.*\]/){
+						($urldate,$pospages)=($posyear=~m/.*\[(.*)\]\.(.*)/);
+						print 'urldate=',"$urldate \n";
+						print 'pospages=',"$pospages \n";
+					}
+					else{#不存在页码,又不存在引用日期的话,那么会有一个点和空格
+						($pospages)=($posyear=~m/.*\s(.*)/);
+						print 'pospages=',"$pospages \n";
+					}
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+						($url, $doi)=($pospages=~m/(.*)\.\s*DOI:(.*)\./i);
+						print 'url=',"$url \n";
+						print 'doi=',"$doi \n";
+					}else{
+						($url)=($pospages=~m/(.*)\./i);
+						print 'url=',"$url \n";
+					}
+				}
+			}else{#不存在年份,匹配一下是否存在冒号和页码
+				if($pospublisher=~m/.*[^DOIhttp]:.*/i){#当存在不是doi或http后面的冒号时,说明有页码
+					($publisher, $pages, $pospages)=($pospublisher=~m/([^:]*):([^\.]*)\.(.*)/);
+					print 'publisher=',"$publisher \n";
+					print 'pages    =',"$pages \n";
+					print 'pospages =',"$pospages \n";
+					if($pages=~m/\[.*\]/){
+						($pagesa, $urldate)=($pages=~m/(.*)\[(.*)\]/);
+						$pages=$pagesa;
+						print 'urldate=',"$urldate \n";
+						print 'pages=',"$pages \n";
+					}
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+						($url, $doi)=($pospages=~m/(.*)\.\s*DOI:(.*)\./i);
+						print 'url=',"$url \n";
+						print 'doi=',"$doi \n";
+					}else{
+						($url)=($pospages=~m/(.*)\./i);
+						print 'url=',"$url \n";
+					}
+				}else{#没有页码冒号以点作为出版者后的分隔点
+					($publisher, $pospages)=($pospublisher=~m/([^\.]*)\.(.*)/);
+					print 'publisher=',"$publisher \n";
+					print 'pospages =',"$pospages \n";
+					if($publisher=~m/\[.*\]/){
+						($publishera, $urldate)=($publisher=~m/(.*)\[(.*)\]/);
+						$publisher=$publishera;
+						print 'urldate=',"$urldate \n";
+						print 'publisher=',"$publisher \n";
+					}
+					if($pospages=~m/DOI/i){#匹配存在doi的话
+						($url, $doi)=($pospages=~m/(.*)\.\s*DOI:(.*)\./i);
+						print 'url=',"$url \n";
+						print 'doi=',"$doi \n";
+					}else{
+						($url)=($pospages=~m/(.*)\./i);
+						print 'url=',"$url \n";
+					}
+				}
+				if($publisher=~m/,$/){$publisher=~s/,$//;}#去掉最后的逗号
+				unless($address){#当没有出版地时,也没有必要存在
+						$type=$publisher;
+						$publisher='';
+				}
+			}
+		if ($publisher=~m/.*\[s-n-\].*/) {#当存在英文的[s-n-]
+			$publisher=~s/\[s-n-\]/\[s\.n\.\]/; #将[s-n-]换回[s.n.]
+		}
+	}
+
+
+	
+close (FHR);
+close (FHW);
\ No newline at end of file


Property changes on: trunk/Master/texmf-dist/doc/latex/biblatex-gb7714-2015/gb7714texttobib.pl
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Modified: trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015.bbx
===================================================================
--- trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015.bbx	2021-09-11 20:37:25 UTC (rev 60476)
+++ trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015.bbx	2021-09-11 20:37:42 UTC (rev 60477)
@@ -11,7 +11,7 @@
 %
 %   版本和时间信息
 %
-\def\versionofgbtstyle{2021/08/19 v1.0z}
+\def\versionofgbtstyle{2021/09/11 v1.1a}
 \def\versionofbiblatex{\abx at version}
 \ProvidesFile{gb7714-2015.bbx}[\versionofgbtstyle biblatex bibliography style]
 %\RequireBiber[3]%显式指定用biber后端,当用bibtex时会报错,但其实不会影响编译,只是采用bibtex后无法达成格式需求
@@ -907,7 +907,7 @@
         and         = {\addcomma},%将第2和3人名间的and符号改成逗号,用\finalnamedelim命令也可以定义,参见3.9.1节
         andcn       = {\addcomma},%and本地化字符串的中文对应词
         andincitecn = {\str at andcn},%将标注中的分开,便于与文献表中的区分
-        andincite   = {\addcomma},
+        andincite   = {\addcomma\space},%注意add开头的命令会其把前面的空格去掉
         %andothers   = {et al.},%将超过3个人名的省略,et al.改成为 等
         andotherscn   = {\str at andotherscn},%将超过3个人名的省略,et al.改成为 等
         andothersincitecn={\str at andotherscn},%将标注中的分开,便于与文献表中的区分
@@ -2445,14 +2445,14 @@
     \iffieldequalstr{\userfieldabcde}{chinese}{\bibstring{andincitecn}}{}%
     \iffieldequalstr{\userfieldabcde}{korean}{\bibstring{andkr}}{}%
     \iffieldequalstr{\userfieldabcde}{japanese}{\bibstring{andjp}}{}%
-    \iffieldequalstr{\userfieldabcde}{english}{\space\bibstring{andincite}\space}{}%
-    \iffieldequalstr{\userfieldabcde}{french}{\space\bibstring{and}\space}{}%
-    \iffieldequalstr{\userfieldabcde}{russian}{\space\bibstring{and}\space}{}%
+    \iffieldequalstr{\userfieldabcde}{english}{\bibstring{andincite}}{}%
+    \iffieldequalstr{\userfieldabcde}{french}{\bibstring{and}}{}%
+    \iffieldequalstr{\userfieldabcde}{russian}{\bibstring{and}}{}%
 %\space%
   \or%
   \bibstring{andincitecn}%\space%
   \or%
-\space\bibstring{andincite}\space%
+\bibstring{andincite}%
   \fi}
 
 \DeclareDelimFormat[bib,biblist]{finalnamedelim}{%
@@ -2472,9 +2472,9 @@
     \iffieldequalstr{\userfieldabcde}{russian}{\bibstring{and}}{}%
 \space%
   \or%
-  \bibstring{andcn}\space%
+  \bibstring{andcn}%
   \or%
-  \bibstring{and}\space%
+  \bibstring{and}%
   \fi}
 
 
@@ -2517,6 +2517,7 @@
 \DeclareNameFormat{namefmtselected}{%
 \iffieldundef{namefmtid}{}%
 {\defcounter{gbnamefmtcase}{\thefield{namefmtid}}}%
+%\printtext{\thegbnamefmtcase}%
 \ifcase\value{gbnamefmtcase}%
   \ifgiveninits
     {\usebibmacro{name:gbuppercase}
@@ -2618,9 +2619,11 @@
 %\DeclareDelimFormat[textcite]{andothersdelim}{\addspace}%
 
 %GB/T 7714-2015 风格,全部大写
+\def\gbcaselocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
+\renewcommand*{\revsdnamepunct}{}%%%来源biblatex.def
+}
 \newbibmacro*{name:gbuppercase}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-\renewcommand*{\revsdnamepunct}{}%
+  \gbcaselocalset%
   \ifuseprefix%
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2647,8 +2650,7 @@
 
 %GB/T 7714-2015 风格,大小写不变,根据bib文件内输入原样输出
 \newbibmacro*{name:gblowercase}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+  \gbcaselocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2674,10 +2676,11 @@
 }
 
 %中文常见风格,汉语拼音全拼模式
+\def\gbpinyinlocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
+\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+\renewrobustcmd*{\bibnamedelima}{\mbox{-}}}
 \newbibmacro*{name:gbpinyin}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
-\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-\renewrobustcmd*{\bibnamedelima}{\mbox{-}}%
+\gbpinyinlocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2703,10 +2706,11 @@
      \ifdefvoid{#4}{}{\bibnamedelimd\mkbibnamesuffix{#4}\isdot}}%
 }
 %中文常见风格,汉语拼音全拼模式
+\def\gbquanpinlocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
+\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+\renewrobustcmd*{\bibnamedelima}{}}
 \newbibmacro*{name:gbquanpin}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
-\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-\renewrobustcmd*{\bibnamedelima}{}%
+\gbquanpinlocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2737,8 +2741,7 @@
   {}{
     %GB/T 7714-2015 风格,全部大写
     \renewbibmacro*{name:gbuppercase}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+    \gbcaselocalset%
       \ifuseprefix
         {\usebibmacro{name:delim}{#3#1}%
          \usebibmacro{name:hook}{#3#1}%
@@ -2771,8 +2774,7 @@
 
     %GB/T 7714-2015 风格,大小写不变,根据bib文件内输入原样输出
     \renewbibmacro*{name:gblowercase}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+      \gbcaselocalset%
       \ifuseprefix
         {\usebibmacro{name:delim}{#3#1}%
          \usebibmacro{name:hook}{#3#1}%
@@ -2797,9 +2799,7 @@
 
     %中文常见风格,汉语拼音全拼模式
     \renewbibmacro*{name:gbpinyin}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-    \renewrobustcmd*{\bibnamedelima}{\mbox{-}}%
+    \gbpinyinlocalset%
       \ifuseprefix
         {\usebibmacro{name:delim}{#3#1}%
          \usebibmacro{name:hook}{#3#1}%
@@ -2823,9 +2823,7 @@
      }
       %中文常见风格,汉语拼音全拼模式
     \renewbibmacro*{name:gbquanpin}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-    \renewrobustcmd*{\bibnamedelima}{}%
+    \gbquanpinlocalset%
       \ifuseprefix
         {\usebibmacro{name:delim}{#3#1}%
          \usebibmacro{name:hook}{#3#1}%

Modified: trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015.cbx
===================================================================
--- trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015.cbx	2021-09-11 20:37:25 UTC (rev 60476)
+++ trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015.cbx	2021-09-11 20:37:42 UTC (rev 60477)
@@ -7,8 +7,7 @@
 %% Released under the LaTeX Project Public License v1.3c or later
 %% ---------------------------------------------------------------
 %%
-\def\versionofgbtstyle{2021/08/19 v1.0z}
-\ProvidesFile{gb7714-2015.cbx}[\versionofgbtstyle biblatex citation style]
+\ProvidesFile{gb7714-2015.cbx}[a biblatex citation style for GB/T 7714-2015]
 
 %
 %   加载标准样式

Modified: trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ay.bbx
===================================================================
--- trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ay.bbx	2021-09-11 20:37:25 UTC (rev 60476)
+++ trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ay.bbx	2021-09-11 20:37:42 UTC (rev 60477)
@@ -10,7 +10,7 @@
 %
 %   版本和时间信息
 %
-\def\versionofgbtstyle{2021/08/19 v1.0z}
+\def\versionofgbtstyle{2021/09/11 v1.1a}
 \def\versionofbiblatex{\abx at version}
 \ProvidesFile{gb7714-2015ay.bbx}[\versionofgbtstyle biblatex bibliography style]
 %\RequireBiber[3]%显式指定用biber后端,当用bibtex时会报错,但其实不会影响编译,只是采用bibtex后无法达成格式需求
@@ -857,7 +857,7 @@
         and         = {\addcomma},%将第2和3人名见的and符号改成 逗号,用\finalnamedelim命令也可以定义,参见3.9.1节
         andcn       = {\addcomma},%\str at andcn\ and本地化字符串的中文对应词
         andincitecn = {\str at andcn},%将标注中的分开,便于与文献表中的区分
-        andincite   = {\addcomma},
+        andincite   = {\addcomma\space},%注意add开头的命令会其把前面的空格去掉
         %andothers   = {et al.},        %将超过3个人名的省略,et al.改成为 等
         andotherscn   = {\str at andotherscn},%将超过3个人名的省略,et al.改成为 等
         andothersincitecn={\str at andotherscn},%将标注中的分开,便于与文献表中的区分
@@ -2297,14 +2297,14 @@
     \iffieldequalstr{\userfieldabcde}{chinese}{\bibstring{andincitecn}}{}%
     \iffieldequalstr{\userfieldabcde}{korean}{\bibstring{andkr}}{}%
     \iffieldequalstr{\userfieldabcde}{japanese}{\bibstring{andjp}}{}%
-    \iffieldequalstr{\userfieldabcde}{english}{\space\bibstring{andincite}\space}{}%
-    \iffieldequalstr{\userfieldabcde}{french}{\space\bibstring{and}\space}{}%
-    \iffieldequalstr{\userfieldabcde}{russian}{\space\bibstring{and}\space}{}%
+    \iffieldequalstr{\userfieldabcde}{english}{\bibstring{andincite}}{}%
+    \iffieldequalstr{\userfieldabcde}{french}{\bibstring{and}}{}%
+    \iffieldequalstr{\userfieldabcde}{russian}{\bibstring{and}}{}%
 %\space%
   \or%
   \bibstring{andincitecn}%\space%
   \or%
-\space\bibstring{andincite}\space%
+\bibstring{andincite}%
   \fi}
 
 \DeclareDelimFormat[bib,biblist]{finalnamedelim}{%
@@ -2324,9 +2324,9 @@
     \iffieldequalstr{\userfieldabcde}{russian}{\bibstring{and}}{}%
 \space%
   \or%
-  \bibstring{andcn}\space%
+  \bibstring{andcn}%
   \or%
-  \bibstring{and}\space%
+  \bibstring{and}%
   \fi}
 
 
@@ -2472,9 +2472,11 @@
 %\DeclareDelimFormat[textcite]{andothersdelim}{\addspace}%
 
 %GB/T 7714-2015 风格,全部大写
+\def\gbcaselocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
+\renewcommand*{\revsdnamepunct}{}%%%来源biblatex.def
+}
 \newbibmacro*{name:gbuppercase}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-\renewcommand*{\revsdnamepunct}{}%
+  \gbcaselocalset%
   \ifuseprefix%
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2501,8 +2503,7 @@
 
 %GB/T 7714-2015 风格,大小写不变,根据bib文件内输入原样输出
 \newbibmacro*{name:gblowercase}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+  \gbcaselocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2528,10 +2529,11 @@
 }
 
 %中文常见风格,汉语拼音全拼模式
+\def\gbpinyinlocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
+\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+\renewrobustcmd*{\bibnamedelima}{\mbox{-}}}
 \newbibmacro*{name:gbpinyin}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
-\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-\renewrobustcmd*{\bibnamedelima}{\mbox{-}}%
+  \gbpinyinlocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2557,10 +2559,11 @@
      \ifdefvoid{#4}{}{\bibnamedelimd\mkbibnamesuffix{#4}\isdot}}%
 }
 %中文常见风格,汉语拼音全拼模式
+\def\gbquanpinlocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
+\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+\renewrobustcmd*{\bibnamedelima}{}}
 \newbibmacro*{name:gbquanpin}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
-\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-\renewrobustcmd*{\bibnamedelima}{}%
+\gbquanpinlocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2591,8 +2594,7 @@
   {}{
     %GB/T 7714-2015 风格,全部大写
     \renewbibmacro*{name:gbuppercase}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+      \gbcaselocalset%
       \ifuseprefix
         {\usebibmacro{name:delim}{#3#1}%
          \usebibmacro{name:hook}{#3#1}%
@@ -2625,8 +2627,7 @@
 
     %GB/T 7714-2015 风格,大小写不变,根据bib文件内输入原样输出
     \renewbibmacro*{name:gblowercase}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+      \gbcaselocalset%
       \ifuseprefix
         {\usebibmacro{name:delim}{#3#1}%
          \usebibmacro{name:hook}{#3#1}%
@@ -2651,9 +2652,7 @@
 
     %中文常见风格,汉语拼音全拼模式
     \renewbibmacro*{name:gbpinyin}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-    \renewrobustcmd*{\bibnamedelima}{\mbox{-}}%
+      \gbpinyinlocalset%
       \ifuseprefix
         {\usebibmacro{name:delim}{#3#1}%
          \usebibmacro{name:hook}{#3#1}%
@@ -2677,9 +2676,7 @@
      }
       %中文常见风格,汉语拼音全拼模式
     \renewbibmacro*{name:gbquanpin}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-    \renewrobustcmd*{\bibnamedelima}{}%
+      \gbquanpinlocalset%
       \ifuseprefix
         {\usebibmacro{name:delim}{#3#1}%
          \usebibmacro{name:hook}{#3#1}%

Modified: trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ay.cbx
===================================================================
--- trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ay.cbx	2021-09-11 20:37:25 UTC (rev 60476)
+++ trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ay.cbx	2021-09-11 20:37:42 UTC (rev 60477)
@@ -7,8 +7,7 @@
 %% Released under the LaTeX Project Public License v1.3c or later
 %% ---------------------------------------------------------------
 %%
-\def\versionofgbtstyle{2021/08/19 v1.0z}
-\ProvidesFile{gb7714-2015ay.cbx}[\versionofgbtstyle biblatex citation style]
+\ProvidesFile{gb7714-2015.cbx}[a biblatex citation style for GB/T 7714-2015]
 
 %
 %   加载标准样式

Modified: trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ms.bbx
===================================================================
--- trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ms.bbx	2021-09-11 20:37:25 UTC (rev 60476)
+++ trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ms.bbx	2021-09-11 20:37:42 UTC (rev 60477)
@@ -11,7 +11,7 @@
 %
 %   版本和时间信息
 %
-\def\versionofgbtstyle{2021/08/19 v1.0z}
+\def\versionofgbtstyle{2021/09/11 v1.1a}
 \def\versionofbiblatex{\abx at version}
 \ProvidesFile{gb7714-2015ms.bbx}[\versionofgbtstyle biblatex bibliography style]
 %\RequireBiber[3]%显式指定用biber后端,当用bibtex时会报错,但其实不会影响编译,只是采用bibtex后无法达成格式需求
@@ -619,7 +619,7 @@
         and         = {\addcomma},%将第2和3人名间的and符号改成逗号,用\finalnamedelim命令也可以定义,参见3.9.1节
         andcn       = {\addcomma},%and本地化字符串的中文对应词
         andincitecn = {\addcomma},%将标注中的分开,便于与文献表中的区分
-        andincite   = {\addcomma},
+        andincite   = {\addcomma\space},%注意add开头的命令会其把前面的空格去掉
         %andothers   = {et al.},  %将超过3个人名的省略,et al.改成为 等
         andotherscn   = {\str at andotherscn},     %将超过3个人名的省略,et al.改成为 等
         andothersincitecn={\str at andotherscn},%将标注中的分开,便于与文献表中的区分
@@ -1507,9 +1507,11 @@
 %\DeclareDelimFormat[textcite]{andothersdelim}{\addspace}%
 
 %GB/T 7714-2015 风格,全部大写
+\def\gbcaselocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
+\renewcommand*{\revsdnamepunct}{}%%%来源biblatex.def
+}
 \newbibmacro*{name:gbuppercase}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-\renewcommand*{\revsdnamepunct}{}%
+  \gbcaselocalset%
   \ifuseprefix%
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -1536,8 +1538,7 @@
 
 %GB/T 7714-2015 风格,大小写不变,根据bib文件内输入原样输出
 \newbibmacro*{name:gblowercase}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+  \gbcaselocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -1563,10 +1564,11 @@
 }
 
 %中文常见风格,汉语拼音全拼模式
+\def\gbpinyinlocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
+\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+\renewrobustcmd*{\bibnamedelima}{\mbox{-}}}
 \newbibmacro*{name:gbpinyin}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
-\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-\renewrobustcmd*{\bibnamedelima}{\mbox{-}}%
+  \gbpinyinlocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -1593,10 +1595,11 @@
 }
 
 %中文常见风格,汉语拼音全拼模式
+\def\gbquanpinlocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
+\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+\renewrobustcmd*{\bibnamedelima}{}}
 \newbibmacro*{name:gbquanpin}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
-\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-\renewrobustcmd*{\bibnamedelima}{}%
+  \gbquanpinlocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -1952,9 +1955,9 @@
     \iffieldequalstr{\userfieldabcde}{russian}{\bibstring{and}}{}%
 \space%
   \or%
-  \bibstring{andcn}\space%
+  \bibstring{andcn}%
   \or%
-  \bibstring{and}\space%
+  \bibstring{and}%
   \fi}%
 %
 %   url和url日期格式

Modified: trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ms.cbx
===================================================================
--- trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ms.cbx	2021-09-11 20:37:25 UTC (rev 60476)
+++ trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015ms.cbx	2021-09-11 20:37:42 UTC (rev 60477)
@@ -7,8 +7,7 @@
 %% Released under the LaTeX Project Public License v1.3c or later
 %% ---------------------------------------------------------------
 %%
-\def\versionofgbtstyle{2021/08/19 v1.0z}
-\ProvidesFile{gb7714-2015ms.cbx}[\versionofgbtstyle biblatex citation style]
+\ProvidesFile{gb7714-2015.cbx}[a biblatex citation style for GB/T 7714-2015]
 
 %
 %   加载样式

Modified: trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015mx.bbx
===================================================================
--- trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015mx.bbx	2021-09-11 20:37:25 UTC (rev 60476)
+++ trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015mx.bbx	2021-09-11 20:37:42 UTC (rev 60477)
@@ -11,7 +11,7 @@
 %
 %   版本和时间信息
 %
-\def\versionofgbtstyle{2021/08/19 v1.0z}
+\def\versionofgbtstyle{2021/09/11 v1.1a}
 \def\versionofbiblatex{\abx at version}
 \ProvidesFile{gb7714-2015mx.bbx}[\versionofgbtstyle biblatex bibliography style]
 %\RequireBiber[3]%显式指定用biber后端,当用bibtex时会报错,但其实不会影响编译,只是采用bibtex后无法达成格式需求
@@ -666,7 +666,7 @@
         and         = {\addcomma},%将第2和3人名间的and符号改成逗号,用\finalnamedelim命令也可以定义,参见3.9.1节
         andcn       = {\addcomma},%and本地化字符串的中文对应词
         andincitecn = {\addcomma},%将标注中的分开,便于与文献表中的区分
-        andincite   = {\addcomma},
+        andincite   = {\addcomma\space},%注意add开头的命令会其把前面的空格去掉
         %andothers   = {et al.},%将超过3个人名的省略,et al.改成为 等
         andotherscn   = {\str at andotherscn},%将超过3个人名的省略,et al.改成为 等
         andothersincitecn={\str at andotherscn},%将标注中的分开,便于与文献表中的区分
@@ -1914,9 +1914,9 @@
     \iffieldequalstr{\userfieldabcde}{russian}{\bibstring{and}}{}%
 \space%
   \or%
-  \bibstring{andincitecn}\space%
+  \bibstring{andincitecn}%
   \or%
-  \bibstring{andincite}\space%
+  \bibstring{andincite}%
   \fi}
 
 \DeclareDelimFormat[bib,biblist]{finalnamedelim}{%
@@ -1936,9 +1936,9 @@
     \iffieldequalstr{\userfieldabcde}{russian}{\bibstring{and}}{}%
 \space%
   \or%
-  \bibstring{andcn}\space%
+  \bibstring{andcn}%
   \or%
-  \bibstring{and}\space%
+  \bibstring{and}%
   \fi}
 
 
@@ -2082,9 +2082,11 @@
 %\DeclareDelimFormat[textcite]{andothersdelim}{\addspace}%
 
 %GB/T 7714-2015 风格,全部大写
+\def\gbcaselocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
+\renewcommand*{\revsdnamepunct}{}%%%来源biblatex.def
+}
 \newbibmacro*{name:gbuppercase}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-\renewcommand*{\revsdnamepunct}{}%
+  \gbcaselocalset%
   \ifuseprefix%
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2111,8 +2113,7 @@
 
 %GB/T 7714-2015 风格,大小写不变,根据bib文件内输入原样输出
 \newbibmacro*{name:gblowercase}[4]{\bibauthorfont%
-    \renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉
-    \renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+  \gbcaselocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2138,10 +2139,11 @@
 }
 
 %中文常见风格,汉语拼音全拼模式
+\def\gbpinyinlocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
+\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+\renewrobustcmd*{\bibnamedelima}{\mbox{-}}}
 \newbibmacro*{name:gbpinyin}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
-\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-\renewrobustcmd*{\bibnamedelima}{\mbox{-}}%
+  \gbpinyinlocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%
@@ -2168,10 +2170,11 @@
 }
 
 %中文常见风格,汉语拼音全拼模式
+\def\gbquanpinlocalset{\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
+\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
+\renewrobustcmd*{\bibnamedelima}{}}
 \newbibmacro*{name:gbquanpin}[4]{\bibauthorfont%
-\renewrobustcmd*{\bibinitperiod}{}%将名字简写后的点去掉,%来源biblatex2.STY
-\renewcommand*{\revsdnamepunct}{}%%来源biblatex.def
-\renewrobustcmd*{\bibnamedelima}{}%
+  \gbquanpinlocalset%
   \ifuseprefix
     {\usebibmacro{name:delim}{#3#1}%
      \usebibmacro{name:hook}{#3#1}%

Modified: trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015mx.cbx
===================================================================
--- trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015mx.cbx	2021-09-11 20:37:25 UTC (rev 60476)
+++ trunk/Master/texmf-dist/tex/latex/biblatex-gb7714-2015/gb7714-2015mx.cbx	2021-09-11 20:37:42 UTC (rev 60477)
@@ -7,8 +7,7 @@
 %% Released under the LaTeX Project Public License v1.3c or later
 %% ---------------------------------------------------------------
 %%
-\def\versionofgbtstyle{2021/08/19 v1.0z}
-\ProvidesFile{gb7714-2015mx.cbx}[\versionofgbtstyle biblatex citation style]
+\ProvidesFile{gb7714-2015.cbx}[a biblatex citation style for GB/T 7714-2015]
 
 %
 %   加载标准样式



More information about the tex-live-commits mailing list.