FIX: 的 DataSet.WriteXML 方法輸出與科學標記法的十進位值,並在後續 DataSet.ReadXML 方法呼叫會讓 System.FormatException 的例外狀況

文章翻譯 文章翻譯
文章編號: 321542 - 檢視此文章適用的產品。
全部展開 | 全部摺疊

在此頁中

徵狀

當您使用 [XML 文件中包含屬性或具有小數點的值,例如 0.00001 的項目結構描述就會標示成十進位該屬性或項目。如果您使用 DataSet.ReadXML 方法來讀取 XML 檔案,,然後將值寫回 XML 檔案使用 DataSet.WriteXML 方法,為輸出中包含科學標記法的值。如果您再次使用 DataSet.ReadXML 方法您會收到下列的例外狀況錯誤訊息:
System.FormatException-輸入字串不正確的格式。

發生的原因

它會將寫入的十進位數字時,會 DataSet.WriteXML 方法在內部呼叫 Decimal.ToString 方法。Decimal.ToString 方法會寫入科學標記法的十進位數字,例如 0.00001。您不能設定 DataSet 物件進行的科學標記法來讀取做為十進位值的 NumberStyles 列舉型別。因此,當您使用 DataSet.ReadXML 方法來讀取數回成資料集 FormatException 例外狀況發生。

解決方案

支援的 Hotfix 現在可以從 Microsoft,但它只用來修正本文所述的問題。僅適用於發生此特定問題的系統。此 Hotfix 可能會接受其他測試。因此,如果您不會嚴重影響這個問題,我們建議您等候下一個包含此 Hotfix 的 Service Pack。

如果要立即解決這個問題,洽詢 Microsoft 技術支援部以取得該 Hotfix。如需 Microsoft 產品支援服務電話號碼及支援成本的相關資訊的完整清單,請造訪下列 Microsoft 網站]:
http://support.microsoft.com/contactus/?ws=support
附註 在特殊情況下通常會因支援電話所產生的費用可能就不收取如果 Microsoft 支援人員認為某特定更新程式可以解決您的問題。平常的支援成本將會套用到其他支援問題是所做不限定特定有問題的更新程式。此 Hotfix 的英文版在檔案屬性 (或更新版本的檔案屬性) 如下列表格中所列。這些檔案的日期和時間為 Coordinated Universal Time (UTC)。當您檢視檔案資訊時,會將它轉換為當地時間。若要到 UTC 與當地時間差異使用 [中日期] 和 [時間] 工具,在 [控制台] 中的 [時區] 索引標籤]。
   Date         Time   Version       Size       File name
   -----------------------------------------------------------
   03-May-2002  02:17  1.0.3705.271  1,294,336  System.xml.dll   

其他可行方案

您可以標記值為結構描述中的十進位字串而不是,您可以手動將字串轉換為十進位的數字值利用 Decimal.Parse 方法 AllowExponent NumberStyles 旗標。

狀況說明

Microsoft 已確認<適用於>一節所列之 Microsoft 產品確實有此問題。

其他相關資訊

重現這個問題的步驟

這個方法會使用 DataSet 物件來讀取、 寫入,並從 XML 讀取十進位值的文件:
  1. 建立新的 Microsoft Visual C#.NET 主控台應用程式。
    1. 啟動 Microsoft Visual Studio.NET。
    2. 在 [檔案] 功能表上指向 [新增],然後按一下 [專案]。
    3. 在 [專案類型 下, 按一下 [Visual C# 專案,] 然後按一下 [範本] 下方的 [主控台應用程式]。依照預設值,會建立名為類別 1 的類別。
  2. 將下列程式碼加入 Class1.cs 檔案的開頭使用陳述式:
    using System.Data;
    using System.Xml; 
    
  3. 將下列程式碼加入 [Main] 欄位中 Class1.cs:
    DataSet ds = new DataSet();
    ds.ReadXmlSchema("..\\..\\XMLSchema1.xsd");
    ds.ReadXml("..\\..\\XMLFile1.xml");
    ds.WriteXml("..\\..\\XMLFile1.xml");		
    ds.ReadXml("..\\..\\XMLFile1.xml");
    
  4. 在 [方案總管] 中以滑鼠右鍵按一下專案名稱,並指向 [新增,然後按一下 [加入新項目加入新項目 方塊隨即出現。
  5. 範本,] 下方按一下 [XML 結構描述,然後按一下 [開啟舊檔]。根據預設值,XMLSchema1,即建立。
  6. 切換至 [XML] 欄位,然後使用下列程式碼取代該程式:
    <?xml version="1.0" standalone="yes"?>
    <xs:schema id="NewDataSet" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
      <xs:element name="NewDataSet" msdata:IsDataSet="true">
        <xs:complexType>
          <xs:choice maxOccurs="unbounded">
            <xs:element name="Table">
              <xs:complexType>
                <xs:sequence>
                  <xs:element name="name" type="xs:string" minOccurs="0" />
                  <xs:element name="tax" type="xs:decimal" minOccurs="0" />
                </xs:sequence>
              </xs:complexType>
            </xs:element>
          </xs:choice>
        </xs:complexType>
      </xs:element>
    </xs:schema>
    
  7. 重複步驟 4,按一下 [XML 檔],請在 [範本 下, 然後再按一下 [開啟舊檔。根據預設值,XMLFile1,即建立。
  8. 程式碼取代下列程式碼:
    <?xml version="1.0" standalone="yes" ?>
    <diffgr:diffgram xmlns:msdata="urn:schemas-microsoft-com:xml-msdata" xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
    	<NewDataSet>
    		<Table diffgr:id="Table1" msdata:rowOrder="0">
    			<name>test </name>
    			<tax>0.00001</tax>
    		</Table>
    		<Table diffgr:id="Table2" msdata:rowOrder="1">
    			<name>234</name>
    			<tax>12</tax>
    		</Table>
    	</NewDataSet>
    </diffgr:diffgram>
    
  9. 在 [偵錯] 功能表上按一下 [開始]。
您會收到 < 徵狀 > 一節所述之錯誤訊息。

屬性

文章編號: 321542 - 上次校閱: 2005年10月11日 - 版次: 1.6
這篇文章中的資訊適用於:
  • Microsoft Visual Studio .NET 2002 Professional Edition
  • Microsoft Visual Studio .NET 2002 Enterprise Architect
  • Microsoft Visual Studio .NET 2002 Enterprise Developer
  • Microsoft Visual Studio .NET 2002 Academic Edition
  • Microsoft .NET Framework 1.0
  • Microsoft .NET Framework 1.0 Service Pack 1
  • Microsoft .NET Framework 1.0 Service Pack 2
關鍵字:?
kbmt kbhotfixserver kbqfe kbvs2002sp1sweep kbprogramming kbschema kbxml kbqfe kbbug kbfix KB321542 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:321542
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。

提供意見

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com