2010-05-25 75 views
0

我似乎無法找到關於如何使用Open XML SDK 2.0向Excel 2007中的單元添加超鏈接的任何文檔或代碼示例。我正在使用下面的代碼,但是有一個步驟我失蹤了?使用Open XML SDK 2.0在Excel 2007中添加超鏈接使用Open XML SDK 2.0

WorksheetPart workSheetPart = ExcelUtilities.GetWorkSheetPart(mWorkBookPart, "Program"); 

workSheetPart.AddHyperlinkRelationship(new Uri("http://www.google.com", UriKind.Absolute), true); 

workSheetPart.Worksheet.Save(); 

mWorkBookPart.Workbook.Save(); 

後來,當我嘗試打開Excel文檔它說,該文件被損壞,因爲關係ID超鏈接無法找到。你如何設置或創建該關係ID?

回答

2

我能夠使用System.IO.Packaging代碼超鏈接添加到單元格:

private void HyperlinkCreate(PackagePart part, XmlNamespaceManager nsm, XmlNode _cellElement, string CellAddress) 
{ 
     Uri _hyperlink = new Uri("http://www.yahoo.com"); 
     XmlNode linkParent = _cellElement.OwnerDocument.SelectSingleNode("//d:hyperlinks", nsm); 
     if (linkParent == null) 
     { 
      // create the hyperlinks node 
      linkParent = _cellElement.OwnerDocument.CreateElement("hyperlinks", @"http://schemas.openxmlformats.org/spreadsheetml/2006/main"); 
      XmlNode prevNode = _cellElement.OwnerDocument.SelectSingleNode("//d:conditionalFormatting", nsm); 
      if (prevNode == null) 
      { 
       prevNode = _cellElement.OwnerDocument.SelectSingleNode("//d:mergeCells", nsm); 
       if (prevNode == null) 
       { 
        prevNode = _cellElement.OwnerDocument.SelectSingleNode("//d:sheetData", nsm); 
       } 
      } 
      _cellElement.OwnerDocument.DocumentElement.InsertAfter(linkParent, prevNode); 
     } 
     string searchString = string.Format("./d:hyperlink[@ref = '{0}']", CellAddress); 
     XmlElement linkNode = (XmlElement)linkParent.SelectSingleNode(searchString, nsm); 
     XmlAttribute attr; 
     if (linkNode == null) 
     { 
      linkNode = _cellElement.OwnerDocument.CreateElement("hyperlink", @"http://schemas.openxmlformats.org/spreadsheetml/2006/main"); 
      // now add cell address attribute 
      linkNode.SetAttribute("ref", CellAddress); 
      linkParent.AppendChild(linkNode); 
     } 

     attr = (XmlAttribute)linkNode.Attributes.GetNamedItem("id", @"http://schemas.openxmlformats.org/officeDocument/2006/relationships"); 
     if (attr == null) 
     { 
      attr = _cellElement.OwnerDocument.CreateAttribute("r", "id", @"http://schemas.openxmlformats.org/officeDocument/2006/relationships"); 
      linkNode.Attributes.Append(attr); 
     }      

     PackageRelationship relationship = null; 
     string relID = attr.Value; 
     if (relID == "") 
      relationship = part.CreateRelationship(_hyperlink, TargetMode.External, @"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink"); 
     else 
     { 
      relationship = part.GetRelationship(relID); 
      if (relationship.TargetUri != _hyperlink) 
       relationship = part.CreateRelationship(_hyperlink, TargetMode.External, @"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink"); 
     } 
     attr.Value = relationship.Id; 
} 

我然後使用Open XML SDK 2.0編譯代碼並沒有關係沒有工作。看來AddHyperlinkRelationship方法實際上並沒有將該關係添加到.rels文件中。我不知道爲什麼,但它肯定對我來說似乎是一個錯誤。

private void HyperlinkCreate(PackagePart part, XmlNamespaceManager nsm, XmlNode _cellElement, string CellAddress) 
    { 

WorksheetPart workSheetPart = ExcelUtilities.GetWorkSheetPart(mWorkBookPart, "Program"); 
      Uri hyperlinkUri = new Uri("http://www.yahoo.com", UriKind.Absolute); 

      Hyperlinks hyperlinks = workSheetPart.Worksheet.Descendants<Hyperlinks>().FirstOrDefault(); 

      // Check to see if the <x:hyperlinks> element exists; if not figure out 
      // where to insert it depending on which elements are present in the Worksheet 
      if (hyperlinks == null) 
      { 
       // Create the hyperlinks node 
       hyperlinks = new Hyperlinks(); 

       OpenXmlCompositeElement prevElement = workSheetPart.Worksheet.Descendants<ConditionalFormatting>().FirstOrDefault(); 
       if (prevElement == null) 
       { 
        prevElement = workSheetPart.Worksheet.Descendants<MergeCells>().FirstOrDefault(); 
        if (prevElement == null) 
        { 
         // No FirstOrDefault needed since a Worksheet requires SheetData or the excel doc will be corrupt 
         prevElement = workSheetPart.Worksheet.Descendants<SheetData>().First(); 
        } 
       } 
       workSheetPart.Worksheet.InsertAfter(hyperlinks, prevElement); 
      } 
      Hyperlink hyperlink = hyperlinks.Descendants<Hyperlink>().Where(r => r.Reference.Equals(CellAddress)).FirstOrDefault(); 
      if (hyperlink == null) 
      { 
       hyperlink = new Hyperlink() { Reference = CellAddress, Id = string.Empty }; 

      } 

      HyperlinkRelationship hyperlinkRelationship = null; 
      string relId = hyperlink.Id; 
      if (relId.Equals(string.Empty)) 
      { 
       hyperlinkRelationship = workSheetPart.AddHyperlinkRelationship(hyperlinkUri, true); 
      } 
      else 
      { 
       hyperlinkRelationship = workSheetPart.GetReferenceRelationship(relId) as HyperlinkRelationship; 
       if (!hyperlinkRelationship.Uri.Equals(hyperlinkUri)) 
       { 
        hyperlinkRelationship = workSheetPart.AddHyperlinkRelationship(hyperlinkUri, true); 
       } 
      } 
      hyperlink.Id = hyperlinkRelationship.Id; 
      hyperlinks.AppendChild<Hyperlink>(hyperlink); 
      workSheetPart.Worksheet.Save();  
     } 
1

您應該將其添加到接受超鏈接的對象(例如單元格)而不是工作表。像這樣的東西應該爲你工作:

using DocumentFormat.OpenXml.Spreadsheet; 
using DocumentFormat.OpenXml; 

namespace GeneratedCode 
{ 
    public class GeneratedClass 
    { 
     // Creates an Worksheet instance and adds its children. 
     public Worksheet GenerateWorksheet() 
     { 
      Worksheet worksheet1 = new Worksheet(){ MCAttributes = new MarkupCompatibilityAttributes(){ Ignorable = "x14ac" } }; 
      worksheet1.AddNamespaceDeclaration("r", "http://schemas.openxmlformats.org/officeDocument/2006/relationships"); 
      worksheet1.AddNamespaceDeclaration("mc", "http://schemas.openxmlformats.org/markup-compatibility/2006"); 
      worksheet1.AddNamespaceDeclaration("x14ac", "http://schemas.microsoft.com/office/spreadsheetml/2009/9/ac"); 
      SheetDimension sheetDimension1 = new SheetDimension(){ Reference = "A1" }; 

      SheetViews sheetViews1 = new SheetViews(); 
      SheetView sheetView1 = new SheetView(){ TabSelected = true, WorkbookViewId = (UInt32Value)0U }; 

      sheetViews1.Append(sheetView1); 
      SheetFormatProperties sheetFormatProperties1 = new SheetFormatProperties(){ DefaultRowHeight = 14.4D, DyDescent = 0.3D }; 

      SheetData sheetData1 = new SheetData(); 

      Row row1 = new Row(){ RowIndex = (UInt32Value)1U, Spans = new ListValue<StringValue>() { InnerText = "1:1" }, DyDescent = 0.3D }; 

      Cell cell1 = new Cell(){ CellReference = "A1", StyleIndex = (UInt32Value)1U, DataType = CellValues.SharedString }; 
      CellValue cellValue1 = new CellValue(); 
      cellValue1.Text = "0"; 

      cell1.Append(cellValue1); 

      row1.Append(cell1); 

      sheetData1.Append(row1); 

      Hyperlinks hyperlinks1 = new Hyperlinks(); 
      Hyperlink hyperlink1 = new Hyperlink(){ Reference = "A1", Id = "rId1" }; 

      hyperlinks1.Append(hyperlink1); 
      PageMargins pageMargins1 = new PageMargins(){ Left = 0.7D, Right = 0.7D, Top = 0.75D, Bottom = 0.75D, Header = 0.3D, Footer = 0.3D }; 

      worksheet1.Append(sheetDimension1); 
      worksheet1.Append(sheetViews1); 
      worksheet1.Append(sheetFormatProperties1); 
      worksheet1.Append(sheetData1); 
      worksheet1.Append(hyperlinks1); 
      worksheet1.Append(pageMargins1); 
      return worksheet1; 
     } 


    } 
} 
+0

我沒有看到直接從Worksheet訪問Cell對象的方法。我正在使用open xml sdk 2.0,並且據我所知,Cell對象 – amurra 2010-05-26 16:08:58

+0

上沒有.Hyperlink屬性,有些事情隨着RTM 2.0而改變。見上面反映的例子。 – 2010-05-26 17:46:47

+0

是的,代碼將工作,但我已經有一個現有的工作表,並希望添加超鏈接到已存在的單元格。 – amurra 2010-05-27 15:22:14

5

另一種可能性(我使用的)是使用Excel的HYPERLINK公式。我需要在每個單元格中創建單獨的超鏈接,但單元格必須顯示不同的文本(我必須在單元格中顯示跟蹤號碼,但每個跟蹤號碼都有一個超鏈接到運營商的站點,並且必須處理多個運營商)。

一旦予實例化的單個電池,式中以這種方式施加到每個單元(有無疑衆多方式):

// ... 
Cell cell1 = new Cell(){ CellReference = "A1", StyleIndex = (UInt32Value)1U, DataType = CellValues.InlineString }; 
CellValue cellValue1 = new CellValue(); 

CellFormula cellFormula1 = new CellFormula() { Space = SpaceProcessingModeValues.Preserve }; 
cellFormula1.Text = @"HYPERLINK(""http://www.theclash.com"", ""Radio Clash"")"; 
cellValue1.Text = "Radio Clash"; 
cell1.Append(cellFormula1); 
cell1.Append(cellValue1); 
// append cell, etc. 

以這種方式,我能夠創建單獨的超鏈接和文本每個單元格。順便說一句,鏈接將以默認的字體顏色顯示,除非您引用藍色字體的樣式。

希望這會有所幫助。

+0

不錯的選擇。爲我工作。 – Jeff 2015-04-27 14:54:32

相關問題