推薦:解讀.net解決數(shù)據(jù)導(dǎo)出excel時(shí)的格式問題在項(xiàng)目中一般都需要將報(bào)表數(shù)據(jù)導(dǎo)出到EXCEL中,但經(jīng)常出現(xiàn)導(dǎo)出長串?dāng)?shù)據(jù)(如身份證)到EXCEL中后顯示為科學(xué)計(jì)數(shù)法的格式,或者報(bào)表中顯示為001的數(shù)據(jù)導(dǎo)出到Excel后成了1的格式。 下面簡單介紹一下以上問題的解決方法: 1、首先,了解一下excel從web頁面上導(dǎo)出的
MF平臺(tái)支持的字體是專有格式,擴(kuò)展名為tinyfnt,需要用專門的轉(zhuǎn)化工具才能把windows平臺(tái)上的字體轉(zhuǎn)換為tinyfnt字體。在.Net Micro Framework SDK中提供了一個(gè)叫做TFConvert.exe的工具,我們可以用它在命令行下將PC機(jī)上的TrueType或者OpenType字體文件生成tinyfnt字體,供.Net Micro Framework的應(yīng)用程序使用。使用TFconvert 工具進(jìn)行字體轉(zhuǎn)化,首先需要?jiǎng)?chuàng)建一個(gè).fntdef 的文件其是字體的定義文件,其實(shí)它就是一個(gè)是TEXT文本文件,但是以.fntdef結(jié)尾的。本文闡述了在.Net Micro Framework 中以PC機(jī)上的字體顯示漢字的步驟。
1.編輯.fntdef文件
先創(chuàng)建一個(gè)文本文檔(.txt),這里我們以華文行楷字體為例,故取名為hwxk.txt。這個(gè)文件就是我們用來配置導(dǎo)出字體的文件,我們?cè)谄渲刑砑右韵聝?nèi)容:
AddFontToProcess C:"WINDOWS"Fonts"STXINGKA.TTF
SelectFont "WE:400,HE:20,FN:宋體"
ImportRange 32 126
ImportRange 19968 40869
配置文件中常用的命令如下:
1)、AddFontToProcess
格式:AddFontToProcess path
說明:填寫中文字庫的路徑信息(字庫源的路徑,需要輸入絕對(duì)路徑),如果路徑里有空格,一定用引號(hào)括起來,如示例所示:
AddFontToProcess C:"Windows"Fonts"Miramo.ttf
AddFontToProcess "C:""Program Files""Microsoft .NET Micro Framework""v2.0.3036""Tools""Fonts""TrueType""Miramo.ttf"
2)
3)
2. 打開命令行工具
在桌面上點(diǎn)擊“開始”à“運(yùn)行”à鍵入CMD,用cd指令導(dǎo)航到SDK的Tools文件夾下,利用dir命令,我們可以看到該目錄的內(nèi)容如圖:

3.使用TFConvert工具
我們假設(shè)在c盤下已經(jīng)創(chuàng)建了samplefonts的目錄,把TFconvert.exe 和hwxk.ttf (以華文行楷作為例子)復(fù)制到該目錄下,同時(shí)把剛才創(chuàng)建的.fntdef 如hwxk.fntdef 也復(fù)制到該目錄下。建議大家在windows xp下進(jìn)行這個(gè)工具的使用。
TFconvert 使用方法: TFconvert <input file> <output file>
Input file= 字體定義文件.fntdef,
output file =字體輸出文件 .tinyfnt
在dos 命令行下 切換到samplesfont 目錄下,輸入:
TFconvert c:"samplefonts"hwxk.fntdef c:"samplefonts"hwxk.tinyfnt
回車即可,這樣在該目錄下就有hwxk.tinyfnt 文件生成。當(dāng)然,這里的目錄也可以是你自定義的。
4.測(cè)試
在Visual Studio中新建一個(gè)Windows Application。首先雙擊Resources.resx,在出現(xiàn)的Tab頁中,我們將String1的內(nèi)容由“Hello World”改為你要顯示的漢語,然后點(diǎn)擊左上角的String旁邊的小箭頭,選擇Files:
然后點(diǎn)擊旁邊的“Add Resouces”右邊的小箭頭,選擇“Add Existing File”,然后瀏覽到我們之前生成的tinyfnt所在文件目錄下。選擇hwxk.tinyfnt,將它添加到資源文件中。
然后我們打開Program.cs,默認(rèn)生成的代碼中將:
text.Font = Resources.GetFont(Resources.FontResources.small);
改為:
text.Font = Resources.GetFont(Resources.FontResources.hwxk);
重新編譯后,在模擬器中就能看到中文字體了,如下圖:

5.?dāng)U展?jié)h字文件
在前面的實(shí)驗(yàn)中,雖然正確的顯示出了漢字,但是也許有人會(huì)問,為什么fntdef文件中FN會(huì)是“宋體”呢,不是華文行楷么?事實(shí)上,當(dāng)你嘗試把FN從宋體改為其他名稱是,目前版本的TFConvert會(huì)在命令行中打印出一條錯(cuò)誤信息:“Font cannot be found matching Selectfont descriptor Facename .Expected ‘??’,found ‘??’”。下面我們就來看看,如何解決這個(gè)問題,而達(dá)到正常顯示所有中文字體的目的。
首先,我們需要使用fontcreator工具來修改中文字體的“font name” 該工具大家可以在網(wǎng)上下載,這里簡單介紹下如何使用該工具來修改
A、 使用fontcreator 工具打開選定的中文字體,如“微軟雅黑”
B、 選擇菜單中“Format”,選擇“Naming”出現(xiàn)如下圖:

在“Platform”中選擇“Microsoft unicode BMP only”,在“Language”中選擇“Chinese-PRC”
注意其中的“Include font family name”、“Include unique font identifier” 和“Include full font name”選項(xiàng),由于該fontcreator工具沒有漢化,所有這些選項(xiàng)顯示都是字符而不是具體的中文字體的名稱
C、 在上面的界面中在“Language”選擇“English-united states”出現(xiàn)如下圖:

同時(shí)注意其中的“Include font family name”、“Include unique font identifier” 和“Include full font name”選項(xiàng),這些選項(xiàng)都包含了“Microsoft YaHei”的字樣
D、 開始修改:把C步驟中的“Microsoft YaHei”字樣內(nèi)容復(fù)制到B步驟中的相應(yīng)選項(xiàng)中,如下圖:

修改后按“ok”,并保存該字體。
E、 同時(shí)修改.fntdef 中的內(nèi)容:
AddFontToProcess C:"SampleFonts"MSYH.ttf
SelectFont "WE:400,FN:Microsoft YaHei"
#import upper case letters
ImportRange 32 126
ImportRange 19968 40869
這樣你重新運(yùn)行Tfconvert工具進(jìn)行轉(zhuǎn)換的時(shí)候就不會(huì)出現(xiàn)如下的錯(cuò)誤提示:

說明:上面所修改的選項(xiàng)中的內(nèi)容可以替換為MsYaHei ,或其他可以代表微軟雅黑字體的英文名稱都可以,同時(shí)你可以試著把這些選項(xiàng)的內(nèi)容替換為“宋體”,這樣你用Tfconvert進(jìn)行轉(zhuǎn)換的時(shí)候也不會(huì)出現(xiàn)錯(cuò)誤提示。個(gè)人認(rèn)為在.Net Micro Framework 的中文字體轉(zhuǎn)換中目前只支持以中文“宋體”為face name(FN)的轉(zhuǎn)換,其他像微軟雅黑、華文細(xì)黑、幼圓為顯示名稱的中文字體,都要把名稱修改為英文名稱才能正常轉(zhuǎn)換。
下圖顯示的是經(jīng)過上述處理后的華文行楷字體:

分享:怎樣實(shí)現(xiàn).net程序的進(jìn)程注入進(jìn)程注入比較常見,比如用IDE調(diào)試 程序 以及一些Spy程序,如果僅僅為了與調(diào)試器通訊,可以使用.net提供的Debugger接口(在EnvDTE.dll的EnvDTE命名空間下).但無論出于什么目的,進(jìn)程注入都是比較好玩的事情,所以不妨一試 . 進(jìn)程注入的 方法 貌似很多(比如像特洛伊
新聞熱點(diǎn)
疑難解答
圖片精選