我正在尝试说服 GVim 7.3正确打印(:hardcopy
)中欧字符(šđč枊ĐČĆŽ)为PDF。我认为相关的设置
set encoding=utf8
set fileencodings=ucs-bom,utf8,cp1250,latin1
set guifont=Consolas:h9:cEASTEUROPE
set printfont=Consolas:h9:cEASTEUROPE
将编码更改为cp1250
(并再次编写它们,因为编码的更改会使其更新),它们会正确打印出来。
现在,我认为utf-8比cp1250更大更完整。为什么在改变之后他们正确地打印出来,或者更重要的是,为什么我不能将它们与enc=utf-8
结合使用(我通常使用它是因为其他字符丰富,通常无法访问)?
:version
VIM - Vi IMproved 7.3 (2010 Aug 15, compiled Oct 27 2010 17:59:02)
MS-Windows 32-bit GUI version with OLE support
Included patches: 1-46
Compiled by Bram@KIBAALE
Big version with GUI. Features included (+) or not (-):
+arabic +autocmd +balloon_eval +browse ++builtin_terms +byte_offset +cindent +clientserver +clipboard +cmdline_compl
+cmdline_hist +cmdline_info +comments +conceal +cryptv +cscope +cursorbind +cursorshape +dialog_con_gui +diff +digraphs -dnd
-ebcdic +emacs_tags +eval +ex_extra +extra_search +farsi +file_in_path +find_in_path +float +folding -footer +gettext/dyn
-hangul_input +iconv/dyn +insert_expand +jumplist +keymap +langmap +libcall +linebreak +lispindent +listcmds +localmap -lua +menu
+mksession +modify_fname +mouse +mouseshape +multi_byte_ime/dyn +multi_lang -mzscheme +netbeans_intg +ole -osfiletype
+path_extra +perl/dyn +persistent_undo -postscript +printer -profile +python/dyn +python3/dyn +quickfix +reltime +rightleft
+ruby/dyn +scrollbind +signs +smartindent -sniff +startuptime +statusline -sun_workshop +syntax +tag_binary +tag_old_static
-tag_any_white +tcl/dyn -tgetent -termresponse +textobjects +title +toolbar +user_commands +vertsplit +virtualedit +visual
+visualextra +viminfo +vreplace +wildignore +wildmenu +windows +writebackup -xfontset -xim -xterm_save +xpm_w32
system vimrc file: "$VIM\vimrc"
user vimrc file: "$HOME\_vimrc"
2nd user vimrc file: "$VIM\_vimrc"
user exrc file: "$HOME\_exrc"
2nd user exrc file: "$VIM\_exrc"
system gvimrc file: "$VIM\gvimrc"
user gvimrc file: "$HOME\_gvimrc"
2nd user gvimrc file: "$VIM\_gvimrc"
system menu file: "$VIMRUNTIME\menu.vim"
Compilation: cl -c /W3 /nologo -I. -Iproto -DHAVE_PATHDEF -DWIN32 -DFEAT_CSCOPE -DFEAT_NETBEANS_INTG -DFEAT_XPM_W32 -DWINVE
R=0x0400 -D_WIN32_WINNT=0x0400 /Fo.\ObjGOLYHTR/ /Ox /GL -DNDEBUG /Zl /MT -DFEAT_OLE -DFEAT_MBYTE_IME -DDYNAMIC_IME -DFEAT_GUI_W3
2 -DDYNAMIC_ICONV -DDYNAMIC_GETTEXT -DFEAT_TCL -DDYNAMIC_TCL -DDYNAMIC_TCL_DLL=\"tcl83.dll\" -DDYNAMIC_TCL_VER=\"8.3\" -DFEAT_PYTH
ON -DDYNAMIC_PYTHON -DDYNAMIC_PYTHON_DLL=\"python27.dll\" -DFEAT_PYTHON3 -DDYNAMIC_PYTHON3 -DDYNAMIC_PYTHON3_DLL=\"python31.dll\"
-DFEAT_PERL -DDYNAMIC_PERL -DDYNAMIC_PERL_DLL=\"perl512.dll\" -DFEAT_RUBY -DDYNAMIC_RUBY -DDYNAMIC_RUBY_VER=191 -DDYNAMIC_RUBY_DLL
=\"msvcrt-ruby191.dll\" -DFEAT_BIG /Fd.\ObjGOLYHTR/ /Zi
Linking: link /RELEASE /nologo /subsystem:windows /LTCG:STATUS oldnames.lib kernel32.lib advapi32.lib shell32.lib gdi32.lib comdl
g32.lib ole32.lib uuid.lib /machine:i386 /nodefaultlib gdi32.lib version.lib winspool.lib comctl32.lib advapi32.lib shell32.lib
/machine:i386 /nodefaultlib libcmt.lib oleaut32.lib user32.lib /nodefaultlib:python27.lib /nodefaultlib:python31.lib e:\t
cl\lib\tclstub83.lib WSock32.lib e:\xpm\lib\libXpm.lib /PDB:gvim.pdb -debug
Press ENTER or type command to continue
键入并使用enc = utf8保存时:
0000000: c5a1 2020 2020 c5a0 0d0a c491 2020 2020 .. ......
0000010: c490 0d0a c48d 2020 2020 c48c 0d0a c487 ...... ......
0000020: 2020 2020 c486 0d0a c5be 2020 2020 c5bd ...... ..
0000030: 0d0a 0d0a 0d0a ......
...使用enc = cp1250
0000000: 9a20 2020 208a 0d0a f020 2020 20d0 0d0a . .... ...
0000010: e820 2020 20c8 0d0a e620 2020 20c6 0d0a . .... ...
0000020: 9e20 2020 208e 0d0a 0d0a . .....
答案 0 :(得分:1)
这是very nice thread讨论非常接近的事情。最后的结论是,“它不起作用,不要那样做” - 只需将文件保存为UTF-8并用其他东西打印,例如:记事本中。
这适用于我的系统:
:silent !notepad /pt "%" "PDFLite"
其中PDFLite
是我的打印到PDF打印机的名称。
编辑:我在vim中使用“utf-8”编码。
答案 1 :(得分:0)
安装paps,它可以通过vim“!paps<%> out.ps”中的命令正常工作,然后你可以使用ps2pdf转换为pdf。
如果在Mac上,请使用'brew install paps'
答案 2 :(得分:0)
我使用与OP相同版本的Vim。我打印那些东西的神奇咒语是:
java.lang.IllegalArgumentException: dexcache == null (and no default could be found; consider setting the 'dexmaker.dexcache' system property)
使用适用于您的代码页。
可能不需要前三行(即保存和重新加载),但它应确保实际转换文本(而不是仅重新解释缓冲区)。需要设置AFAICT :se fenc=cp1252
:w
:e ++enc=cp1252
:se enc=cp1252
:se fenc=cp1252
:se penc=cp1252
:hardcopy
和enc
,penc
只是CYA。然后以您想要的方式使用fenc
。
如果您希望将文件存储在其他代码页(latin1,utf-8等)中,请记得更改相关编码(:hardcopy
,enc
)并重新保存。有fenc
和:se fenc
的程序。然后,您可以继续使用:w
(可能已添加:e
)和++enc=xxx
进行检查,并确保您使用首选代码页处理副本,以及另外一轮:se enc=xxx
和:se fenc=xxx
当你为了安全起见而做的时候。
这有点多余,但这是确定Vim与您在同一页面上的一种方式。正如您已经注意到Windows上的代码页处理(至少是WRT打印)有一些有趣的东西,所以我不一定相信它可以完全在内部完成所有正确的事情。我只是强迫它改变实际的字节表示,然后确保它使用它。