使用OPEN XML SDK 读取EXCEL中的超链接Hyperlink
原理
先创建一个包括全部EXCEL单元格中超链接Hyperlink数据的表,再定位单元格通过列头(如A1,B1)获取超链接信息。本文仅重着于怎样读取EXCEL中的超链接Hyperlink信息。不设计OPEN XML SDK解说。假设须要请參考:
代码
using (SpreadsheetDocument myDoc = SpreadsheetDocument.Open(stream,false)) { WorkbookPart workbookPart = myDoc.WorkbookPart; foreach (var worksheetPart in workbookPart.WorksheetParts) { //全部超链接hyperlink数据表 var hyperlinks = worksheetPart.RootElement.Descendants<Hyperlinks>().First().Cast<Hyperlink>(); var sheet = worksheetPart.Worksheet.Elements<SheetData>().First(); foreach (Row r in sheet.Elements<Row>()) { var cell = (Cell)r.ElementAtOrDefault(1); //举例获取一个单元格 cell = (Cell)r.ElementAt(1); //通过单元格列头信息获取超链接 var hyperlink = hyperlinks.SingleOrDefault(i => i.Reference.Value == cell.CellReference.Value); if (hyperlink != null) { var hyperlinksRelation = worksheetPart.HyperlinkRelationships.SingleOrDefault(i => i.Id == hyperlink.Id); if (hyperlinksRelation != null) { //这是终于我们须要的超链接 var url = hyperlinksRelation.Uri.ToString(); } } } } }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。