程序中通常会有一些错误代码或标识,为了程序中方便这些东西通常不会使用汉字,经常在程序中用的是一些FileError或数字。还有就是在编码中经常使用的枚举标识对象的状态。而通常这些信息会直接的或间接的现实给用户,可用户需要到的是容易理解的汉字描述。以前要么将这
程序中通常会有一些错误代码或标识,为了程序中方便这些东西通常不会使用汉字,经常在程序中用的是一些FileError或数字。还有就是在编码中经常使用的枚举标识对象的状态。而通常这些信息会直接的或间接的现实给用户,可用户需要到的是容易理解的汉字描述。以前要么将这些标识和枚举的转换规则硬编码到程序中,要么就直接提示给用户。前者没有很好的扩展性,而后者则让用户一头雾水。现可以用流行的XML(配置文件)保存提示信息,然后用一个对象将机器中的内码转换为人们容易理解的信息。
转换对象如下:
/**//// ///翻译类,将内部码翻译成容易理解的中文 /// /// ///根据配置文件中的信息,将系统内部码(错误码、成功码)翻译成中文(或人容易理解的语言)。 /// publicstaticclassTranslation ...{ privatestaticSystem.IO.FileSystemWatcherwatcher; privatestaticXmlDocumentcontent; privatestaticstringconfigFile; privatestaticobjectlocker=newobject(); /**//// ///加载配置文件 /// /// publicstaticvoidConfigure(stringconfigFile) ...{ LoadFile(configFile); if(watcher!=null) ...{ watcher.Dispose(); } watcher=newFileSystemWatcher(Path.GetDirectoryName(configFile),Path.GetFileName(configFile)); watcher.Changed =newFileSystemEventHandler(watcher_Changed); } /**//// ///加载默认配置文件 /// publicstaticvoidConfigure() ...{ if(System.Web.HttpContext.Current!=null) ...{ Configure(System.Web.HttpContext.Current.Server.MapPath("~/translation.config")); } else ...{ Configure(System.AppDomain.CurrentDomain.SetupInformation.ApplicationBase "\" "translation.config"); } } /**//// ///加载文件内容 /// /// privatestaticvoidLoadFile(stringconfigFile) ...{ lock(locker) ...{ XmlDocumentdoc=newXmlDocument(); doc.Load(configFile); content=doc; Translation.configFile=configFile; } } /**//// ///当文件变更时,从新加载文件 /// /// /// privatestaticvoidwatcher_Changed(objectsender,FileSystemEventArgse) ...{ LoadFile(configFile); } /**//// ///获取Enum的解释,如果Enum有Flag标记,则使用逗号分隔各个解释 /// /// /// publicstaticstringGetEnumDescription(EnumenumValue) ...{ returnGetEnumDescription(enumValue,","); } /**//// ///获取Enum的解释,如果Enum有Flag标记,则使用sparator分隔各个解释 /// /// /// /// publicstaticstringGetEnumDescription(EnumenumValue,stringsparator) ...{ Typetype=enumValue.GetType(); //检查类型是否有Flags特性 object[]attrs=type.GetCustomAttributes(typeof(FlagsAttribute),false); if(attrs.Length>0) ...{ StringBuilderbuilder=newStringBuilder(); Arrayarr=Enum.GetValues(type); foreach(Enumenuinarr)//循环获取每一个值的解释 ...{ if((Convert.ToUInt64(enumValue)&Convert.ToUInt64(enu))==Convert.ToUInt64(enu))//判断是否有这个值 ...{ builder.Append(GetEnumDes(type,enu.ToString())); builder.Append(sparator); } } if(builder.Length!=0)//拿掉最后的分隔符 builder.Remove(builder.Length-sparator.Length,sparator.Length); returnbuilder.ToString(); } else ...{ returnGetEnumDes(type,enumValue.ToString()); } } /**//// ///获取某一Enum类型值的解释 /// /// /// /// privatestaticstringGetEnumDes(Typetype,stringvalue) ...{ stringxquery="/translation/enum/" type.FullName "/" value; XmlNodenode=content.SelectSingleNode(xquery); if(node!=null) returnnode.InnerText; else returnvalue; } /**//// ///翻译指定值 /// /// /// publicstaticstringGetValueDescription(objectobj) ...{ returnGetValueDescription("default",obj); } /**//// ///在指定组中翻译指定值 /// /// /// /// publicstaticstringGetValueDescription(stringgroup,objectobj) ...{ if(obj==null) return"null"; stringxquery="/translation/description[@group='" group "']/add[@key='" obj.ToString() "']/@value"; XmlNodenode=content.SelectSingleNode(xquery); if(node==null) returnobj.ToString(); else returnnode.Value; } } #p#
在这个对象使用前需要使用Configure方法来加载xml配置文件,默认的配置文件名称为translation.config。转换对象使用单例模式,使用了一个FileSystemWatcher对象来监视XML文件,如果XML有变化,则从新加载。查询XML使用了XPath表达式。
然后即可使用GetEnumDescription和GetValueDescription方法来翻译枚举和标识了。如果没有找到可以翻译的值,则会返回对象的ToString方法的返回值。
示例XML配置:
<?xmlversion="1.0"encoding="utf-8"?> <translation> <enum> <!--此出要用枚举的全名--> <Library.UserType> <Unknow>未知</Unknow> <AfterPayUser>后付费用户</AfterPayUser> <BeforePayUser>预付费用户</BeforePayUser> </Library.UserType> </enum> <descriptiongroup="default"> <addkey="FileErrorl"value="文件已损坏"/> </description> <descriptiongroup="skin"> <addkey="Default"value="默认皮肤"/> </description> <descriptiongroup="topic"> <addkey="space"value="<spanclass='red'>您剩余的空间不足,请您删除部分文件。</span><br/>"/> <addkey="yue"value="<spanclass='red'>您的余额不足,请尽快充值。</span><br/>"/> </description> </translation>
以上是使用XML將機器內碼轉換為人們能夠理解的資訊案例分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

XML/RSS訂閱源的處理涉及解析和優化,常見問題包括格式錯誤、編碼問題和元素缺失。解決方案包括:1.使用XML驗證工具檢查格式錯誤;2.確保編碼一致性並使用chardet庫檢測編碼;3.處理元素缺失時使用默認值或跳過該元素;4.使用高效解析器如lxml和緩存解析結果以優化性能;5.注意數據一致性和安全性,防止XML注入攻擊。

解析RSS文檔的步驟包括:1.讀取XML文件,2.使用DOM或SAX解析XML,3.提取標題、鏈接等信息,4.處理數據。 RSS文檔是一種基於XML的格式,用於發布更新內容,結構包含、和元素,適用於構建RSS閱讀器或數據處理工具。

RSS和XML是網絡內容分發和數據交換的核心技術。 RSS用於發布頻繁更新的內容,XML用於存儲和傳輸數據。通過實際項目中的使用示例和最佳實踐,可以提高開發效率和性能。

XML在RSSFeed中的作用是結構化數據、標準化和提供可擴展性。 1.XML使得RSSFeed的數據結構化,便於解析和處理。 2.XML提供了一種標準化的方式來定義RSSFeed的格式。 3.XML的可擴展性使得RSSFeed可以根據需要添加新的標籤和屬性。

處理XML和RSS數據時,可以通過以下步驟優化性能:1)使用高效的解析器如lxml提升解析速度;2)採用SAX解析器減少內存使用;3)利用XPath表達式提高數據提取效率;4)實施多進程並行處理提升處理速度。

RSS2.0是一種開放標準,允許內容髮布者以結構化的方式分發內容。它包含了豐富的元數據,如標題、鏈接、描述、發布日期等,使得訂閱者能夠快速瀏覽和訪問內容。 RSS2.0的優勢在於其簡潔和擴展性。例如,它允許自定義元素,這意味著開發者可以根據需求添加額外的信息,如作者、分類等。

RSS是一種基於XML的格式,用於發布經常更新的內容。 1.RSSfeed通過XML結構化組織信息,包括標題、鏈接、描述等。 2.創建RSSfeed需按照XML結構編寫,添加元數據如語言和發布日期。 3.高級用法可包含多媒體文件和分類信息。 4.調試時使用XML驗證工具,確保必需元素存在且編碼正確。 5.優化RSSfeed可通過分頁、緩存和保持結構簡潔來實現。通過理解和應用這些知識,可以有效管理和分發內容。

RSS是一種基於XML的格式,用於發布和訂閱內容。 RSS文件的XML結構包括根元素、元素和多個元素,每個代表一個內容條目。通過XML解析器讀取和解析RSS文件,用戶可以訂閱並獲取最新內容。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。