2011-02-20 17 views
0

次のコードを使用して、データセットをc#からExcelにエクスポートしています。私は次の出力を取得しています:Export to excel出力の変更

ABC | 1 | 2/15/2011 21:36 | Systems Analyst | Project Duration 
ABC | 1 | 2/15/2011 21:36 | Systems Analyst | Skill of Team 
ABC | 1 | 2/15/2011 21:36 | Systems Analyst | Process 

私がやりたい何か、しかし、次の形式での出力データであり、列見出しを追加します。 StoryCategoryIDの出力が1の場合はNEGATIVE、出力が0の場合はPOSITIVEを表示したいと思います。助けてください!

Story | Story Type | Date | Project Member | Tag 1 | Tag 2 | Tag 3 

ABC | Negative | 2/15/2011 21:36 | Project Duration | Skill of Team | Process 

コード:すべての

protected void btnExcelExport_Click(object sender, EventArgs e) 
{ 

     string sql = null; 
     string data = null; 
     //string path = save_as.Text; 

     int i = 0; 
     int j = 0; 

     Excel.Application xlApp; 
     Excel.Workbook xlWorkBook; 
     Excel.Worksheet xlWorkSheet; 
     object misValue = System.Reflection.Missing.Value; 

     xlApp = new Excel.ApplicationClass(); 
     xlWorkBook = xlApp.Workbooks.Add(misValue); 
     xlWorkSheet = (Excel.Worksheet)xlWorkBook.Worksheets.get_Item(1); 

     //connectionString = "data source=servername;initial catalog=databasename;user id=username;password=password;"; 
     SqlConnection cnn = new SqlConnection(GetConnectionString()); 
     cnn.Open(); 
     sql = "SELECT s.Story, s.StoryCategoryID, s.CreationDate, m.CompanyRole, af.Name FROM Story s INNER JOIN ProjectIterationMember pm ON pm.ProjectIterationMemberID = s.ProjectIterationMemberID INNER JOIN Iterations i ON i.ProjectIterationID = pm.ProjectIterationID INNER JOIN Member m ON m.MemberID = pm.MemberID INNER JOIN ProjectStoryFactors psf ON psf.StoryID = s.StoryID INNER JOIN AgileFactors af ON af.AgileFactorID = psf.AgileFactorID WHERE i.ProjectID = '" + proj_id + "'"; 
     SqlDataAdapter dscmd = new SqlDataAdapter(sql, cnn); 
     DataSet ds = new DataSet(); 
     dscmd.Fill(ds); 

     for (i = 0; i <= ds.Tables[0].Rows.Count - 1; i++) 
     { 
      for (j = 0; j <= ds.Tables[0].Columns.Count - 1; j++) 
      { 
       data = ds.Tables[0].Rows[i].ItemArray[j].ToString(); 
       xlWorkSheet.Cells[i + 1, j + 1] = data; 
      } 
     } 

     xlWorkBook.SaveAs("excelDocument" + DateTime.Now.Ticks + ".xls", Excel.XlFileFormat.xlWorkbookNormal, misValue, misValue, misValue, misValue, Excel.XlSaveAsAccessMode.xlExclusive, misValue, misValue, misValue, misValue, misValue); 
     xlWorkBook.Close(true, misValue, misValue); 
     xlApp.Quit(); 

     releaseObject(xlWorkSheet); 
     releaseObject(xlWorkBook); 
     releaseObject(xlApp); 

     //MessageBox.Show("Excel file created , you can find the file c:\\csharp.net-informations.xls"); 
    } 
+0

直接的な解決策ではありませんが、http://excelpackage.codeplex.com/で作業する方が簡単です。 COMの依存関係がなく、書式設定に関して非常に柔軟性があります。 –

答えて

1

まず、性能面、それは、細胞によって細胞を書くために、次にExcelの範囲に書き込むためにはるかに高速です。これを行うには、テーブルのデータから2次元配列を作成し、それを直接範囲に書き込んでください。

ヘッダーについて:必要なテキストをExcelの最初の行に書きます。オートフィルタを設定することもできます。データを書き込むときは、2行目から開始します。

"Positive"または "Negative"に値を変更する場合は、書き込みを開始する前にこれを実行してください。ソースの値を変更するだけです(必要に応じて別のデータテーブルの配列)。

//Create 2-dimensional array with the data from the datatable 
DataTable dt = ds.Tables[0]; 
string[,] arrValues = new string[dt.Rows.Count, dt.Columns.Count]; 

for (int i = 0; i < dt.Rows.Count; i++) 
{ 
    for (int j = 0; j < dt.Columns.Count; j++) 
    { 
     arrValues[i, j] = dt.Rows[i].ItemArray[j].ToString(); 
    } 
} 

//Change the data from the column StoryCategoryID here 
//Just loop through the items in the correct column of the array 
//and check whether it's "0" or "1" 

//Add headers 
for (int i = 0; i < dt.Columns.Count; i++) 
{ 
    xlWorkSheet.Cells[1, i + 1] = dt.Columns[i].ColumnName; 
    //Or any name you like 
} 

//Create range (start at row 2 because of header-row) 
Range xlRange = (Range)xlWorkSheet.Cells[2, 1]; 
xlRange = xlRange.Resize[dt.Rows.Count, dt.Columns.Count]; 

//Fill range 
xlRange.Value = arrValues; 

//Format document 
xlWorkSheet.EnableAutoFilter = true; 
xlWorkSheet.Cells.AutoFilter(1); 
xlWorkSheet.Range["A1", "A1"].EntireRow.Font.Bold = true; 
xlWorkSheet.Columns.AutoFit(); 

値をセルで渡す代わりに範囲を使用する理由は、パフォーマンスによるものです。約1500レコード(15 coloumns)の場合、Excelファイルを作成するのに約7または8分かかりました。この方法では(範囲で)約5または10秒かかりました。

(これはいくつかのVB.Netコードであり、私は心配していませんでした。他のパラメータで渡す必要がある "misValue"があるかもしれませんが、私は思っています)