2017-01-18 20 views
0

Excelファイルをダウンロードしてから読み込むc#webjobがあります。列の1つに、データベースに保存したいリンクが含まれています。私は現在、ExcelDataReaderを使用してExcelファイルをDataSetに変換してから、データを取得するために行をループします。変換後、問題の列はリンクテキストを含む文字列にすぎません。ExcelのセルからリンクURLを抽出する方法

Excelでのように聞こえるが、ハイパーリンクは別の場所に保存されており、ExcelファイルをDataSetに変換するとその情報は保持されません。

私はExcelDataReaderを使用するように設定されていませんが、これらのリンクURLを抽出するソリューションを見つけるには、3番目の部分のソフトウェアを支払う必要はありません。ここで

私はリファレンスとして、これまで持っている単純なコードです:私は私のExcelファイルを読むためにEPPLUSを使用して、ハイパーリンクのデータを取得することができるということになった

FileStream stream = File.Open(fileLocation, FileMode.Open, FileAccess.Read); 
IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream); 
excelReader.IsFirstRowAsColumnNames = true; 

DataSet result = excelReader.AsDataSet(); 

int count = 0; 

foreach (DataRow row in result.Tables["WorkSheetName"].DataTable.Rows) 
{ 
    var item = new myObject(); 

    item.Prop1 = long.Parse(row["Column3"].ToString()); 
    item.Prop2 = row["Column7"].ToString(); //The link, currently only seeing link text 

    this.myDbContext.myTable.Add(item); 
    await this.myDbContext.SaveChangesAsync(); 

    count += 1; 
} 
+0

私は、あなたが文字列を持っていて、URLにそれを変換したい、理解していけませんか? –

+0

Excelファイルではハイパーリンクです。文字列としてセルを読むときは、リンクテキストのみを抽出し、リンク先のURLは抽出しません。 –

+0

VBAでは、セルに接続されたハイパーリンクのアドレスプロパティがURLを返します。セルに接続されたハイパーリンクオブジェクトは、ハイパーリンクコレクションの最初のアイテムになります。だからVBAでは、Range( "A1")、URLのためのHyperlinks(1).address'のようになります。 C#で同様のことをすることはできますか? –

答えて

1

コード:

var pck = new ExcelPackage(excelFileStream); 
ExcelWorksheet ws = pck.Workbook.Worksheets.First(); 

DataTable dt = new DataTable(ws.Name); 
int totalCols = ws.Dimension.End.Column; 
int totalRows = ws.Dimension.End.Row; 
int startRow = 3; 
ExcelRange wsRow; 
DataRow dr; 
foreach (var firstRowCell in ws.Cells[2, 1, 2, totalCols]) 
{ 
    dt.Columns.Add(firstRowCell.Text); 
} 

for (int rowNum = startRow; rowNum <= totalRows; rowNum++) 
{ 
    wsRow = ws.Cells[rowNum, 1, rowNum, totalCols]; 
    dr = dt.NewRow(); 
    int rowCnt = 0; 
    foreach (var cell in wsRow) 
    { 
     if (rowCnt == 7) 
     { 
      if (cell.Hyperlink != null) 
      { 
       dr[cell.Start.Column - 1] = cell.Hyperlink.AbsoluteUri; 
      } 
     } 
     else 
     { 
      dr[cell.Start.Column - 1] = cell.Text; 
     } 

     rowCnt++; 
    } 

    if (!String.IsNullOrEmpty(dr[7].ToString())) 
    { 
     dt.Rows.Add(dr); 
    } 
} 

return dt; 
関連する問題