FIX: A System.Xml.Xsl.XsltException 時,會發生例外狀況您嘗試使用使用格式數字函式的 XSLT 樣式表執行 XSLT 轉換

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

在此頁中

結論

您建立使用 格式數字 函式的可延伸樣式表語言轉換 (XSLT) 樣式表 。在 Microsoft Visual Studio.NET 中執行 XSLT 轉換,嘗試將正數轉換為字串,使用這個樣式表時就會發生 System.Xml.Xsl.XsltException 例外狀況。如果要解決這個問題,下載並安裝 Hotfix]。若要取得該 Hotfix,請連絡 Microsoft 產品支援服務]。

徵狀

您可以建立一個可延伸樣式表語言轉換 (XSLT) 樣式表,會使用 格式數字 函式。在 Microsoft Visual Studio.NET 中當您嘗試藉由將正數轉換成字串,使用這個樣式表執行 XSLT 轉換會收到下列錯誤訊息:
system.xml.dll 中發生未處理的例外狀況的型別 'System.Xml.Xsl.XsltException'
如果您處理以顯示內部例外狀況和例外狀況訊息的例外狀況時,您會收到下列輸出:
System.ArgumentException: NumberGroupSizes
參數名稱: 數值陣列中的每一項目應介於一到除了的最後一個項目可以是零以外的九。
在 system.globalization.NumberFormatInfo.CheckGroupSize (字串 propName、 Int32 [] groupSize)
在 System.Xml.Xsl.XsltCompileContext.FormatNumber (Double 值,String formatPattern,String formatName)
在 System.Xml.Xsl.FuncFormatNumber.Invoke XsltContext xsltContext、 物件 [] 引數 (XPathNavigator docContext)
在 System.Xml.XPath.XsltFunction.InvokeFunction XPathNavigator qy (XPathNodeIterator Iterator)

函式 'format-number()' 已經失敗。

解決方案

支援的 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-Dec-2003  19:43  1.1.4322.978    1,339,392  System.xml.dll

狀況說明

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

其他相關資訊

重現這個問題的步驟

  1. 建立主控台應用程式專案

    1. 啟動 Microsoft Visual Studio.NET 2003年。
    2. 在 [檔案] 功能表上指向 [新增],然後按一下 [專案]。
    3. 在 [專案類型 下, 按一下 [Visual C# 專案,] 然後按一下 [範本] 下方的 [主控台應用程式]。
    4. 在 [名稱] 方塊中,輸入 FormatNumConsole
    5. 按一下 [確定]。根據預設,Class1.cs 程式碼] 視窗會開啟。
  2. 建立使用格式數字函式的 XSLT 樣式表

    1. 在 [方案總管] 中 FormatNumConsole] 上按一下滑鼠右鍵,並指向 [新增,然後按一下 [加入新項目。出現 [加入新項目-FormatNumConsole] 對話方塊。
    2. 在 [類別,] 下按一下 [本機專案項目]。
    3. 在 [範本 下, 按一下 XSLT 檔案
    4. 在 [名稱] 方塊中輸入 格式 number.xslt,然後按一下 [開啟舊檔]。[格式 number.xslt 程式碼] 視窗隨即開啟。
    5. 取代現有的 XML 程式碼以下列 XML 程式碼來建立 XML 資料的簡報的範本:
      <?xml version="1.0" encoding="UTF-8"?>
      <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
          <xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
          <xsl:template match="/">
              <table>
                  <xsl:apply-templates />
              </table>
          </xsl:template>
          <xsl:template match="number">
              <tr><td><xsl:value-of select="format-number(.,'#,##0;(#,##0)')"/></td></tr>
          </xsl:template>
      </xsl:stylesheet>
  3. 建立提供 XML 資料的 XML 檔案

    1. 在 [方案總管] 中 FormatNumConsole] 上按一下滑鼠右鍵,並指向 [新增,然後按一下 [加入新項目。出現 [加入新項目-FormatNumConsole] 對話方塊。
    2. 在 [範本 下, 按一下 XML 檔案
    3. 在 [名稱] 方塊中輸入 格式 number.xml,然後按一下 [開啟舊檔]。 [格式 number.xml 程式碼] 視窗隨即開啟。
    4. 取代現有的 XML 程式碼以下列 XML 程式碼來提供 XML 資料:
      <?xml version="1.0" encoding="UTF-8"?>
      <root>
          <number>1000</number>
      </root>
  4. 嘗試使用 XSLT 樣式表和 XML 檔案來執行 XSLT 轉換

    1. 切換至 Class1.cs 程式碼視窗。
    2. 下列程式碼,以使用 XslTransform 類別,將 XML 資料轉換使用 XSLT 樣式表來取代現有的程式碼。

      附註在下列程式碼適當檔案路徑中使用 XPathDocument 建構函式和 xsltProcessor.Load 方法的呼叫:
      using System;
      using System.Xml;
      using System.Xml.XPath;
      using System.Xml.Xsl;
      using System.IO;
      using System.Text;
      
      namespace FormatNumConsole
      {
          class Class1
          {
              [STAThread]
              static void Main(string[] args)
              {
                  try
                  {
                      StringBuilder sb = new StringBuilder();
                      StringWriter sw = new StringWriter(sb);
      
                      // Load the XML data that you want to transform.
                      XPathDocument xmlDoc = new XPathDocument("C:\\FormatNumConsole\\format-number.xml");
      
                      // Load the XSLT style sheet that uses the format-number function.
                      XslTransform xsltProcessor = new XslTransform();
                      xsltProcessor.Load("C:\\FormatNumConsole\\format-number.xslt");
      
                      // Transform the XML data, and then send the output to the console.
                      xsltProcessor.Transform(xmlDoc,null,sw,null);
                  }
                  catch(Exception ex)
                  {
                      // Display the inner exception and the exception message.
                      Console.WriteLine(ex.InnerException.ToString());
                      Console.WriteLine();
                      Console.WriteLine(ex.Message);
                      Console.ReadLine();
                  }
              }
          }
      }
    3. 建置此應用程式,然後再執行應用程式。 < 徵狀 > 一節所提到的輸出會顯示在主控台視窗中。

?考

如需詳細資訊按一下 [下列面的文件編號,檢視 「 Microsoft 知識庫 」 中發行項]:
824684用來描述 Microsoft 軟體更新標準術語的說明
307494如何使用 Visual C#.NET 資料流將 XSL 轉換套用至 XML
如需詳細資訊請造訪下列 Microsoft 開發人員網路 (MSDN) 網站:
XsltException 類別
http://msdn2.microsoft.com/en-us/library/system.xml.xsl.xsltexception(vs.71).aspx
格式數字函式
http://msdn2.microsoft.com/en-us/library/ws343esk.aspx
XslTransform 類別
http://msdn2.microsoft.com/en-us/library/system.xml.xsl.xsltransform(vs.71).aspx

屬性

文章編號: 832757 - 上次校閱: 2007年5月21日 - 版次: 2.4
這篇文章中的資訊適用於:
  • Microsoft .NET Framework 1.1
關鍵字:?
kbmt kbqfe kbhotfixserver kbbug kbformat kbstyle kbxml kbsample kberrmsg kbcode kbfix KB832757 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:832757
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