//http://karbel.codeplex.com/
//Common Development and Distribution License (CDDL)
using System;
using System.Collections.Generic;
using System.Text;
using Microsoft.Office.Interop.Excel;
using System.Configuration;
using System.Diagnostics;
using System.Reflection;
using System.Data;
using System.Collections;
using System.IO;
namespace Karbel.Excel
{
public class ExcelManager
{
#region Excel
string filePath;
public string FilePath
{
get { return filePath; }
set { filePath = value; }
}
public ExcelManager(string FilePath,bool CreateNew,bool IsVisible)
{
Application = new Microsoft.Office.Interop.Excel.Application();
this.FilePath = FilePath;
this.IsVisible = IsVisible;
if (CreateNew)
{
Workbook = Application.Workbooks.Add(miss);
}
else
{
Workbook = Application.Workbooks.Open(FilePath, false, false, miss, miss, miss, miss, miss, miss, miss, miss, miss, miss, miss, miss);
}
}
private Missing miss = System.Reflection.Missing.Value;
public ExcelManager(string FilePath, bool IsVisible,int WaitSecond)
{
Application = new Microsoft.Office.Interop.Excel.Application();
IsVisible = IsVisible;
Workbook = Application.Workbooks.Open(FilePath, miss, miss, miss, miss, miss, true, miss, miss, false, false, miss, miss, miss, miss);
System.Threading.Thread.Sleep(1000 * WaitSecond);
}
public bool IsVisible
{
get
{
return Application.Visible;
}
set
{
Application.Visible = value;
}
}
#endregion
#region Application
private Microsoft.Office.Interop.Excel.Application application;
public Microsoft.Office.Interop.Excel.Application Application
{
get { return application; }
set { application = value; }
}
#endregion
#region Workbook
private Microsoft.Office.Interop.Excel.Workbook workbook;
public Microsoft.Office.Interop.Excel.Workbook Workbook
{
get { return workbook; }
set { workbook = value; }
}
#endregion
#region Save
public void Save()
{
if (Workbook != null)
{
Workbook.SaveAs(FilePath, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, XlSaveAsAccessMode.xlExclusive, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
}
}
public void SaveAs(string FileName)
{
if (Workbook != null)
{
Workbook.SaveAs(FileName, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, XlSaveAsAccessMode.xlExclusive, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
}
}
#endregion
#region GetSheet
public Microsoft.Office.Interop.Excel.Worksheet GetSheet(int Index)
{
return (Microsoft.Office.Interop.Excel.Worksheet)Workbook.Worksheets.get_Item(Index);
}
public int SheetCount
{
get
{
return Workbook.Worksheets.Count;
}
}
#endregion
#region Border
private void Border(Range range)
{
range.BorderAround(XlLineStyle.xlContinuous, XlBorderWeight.xlMedium, XlColorIndex.xlColorIndexAutomatic, System.Type.Missing);
}
#endregion
#region Kill
public void Kill()
{
if (Application == null)
{
return;
}
FileInfo fi = new FileInfo(FilePath);
//To prevent asking file to save
Random rnd = new Random();
string tempFileName;
try
{
tempFileName = Environment.GetFolderPath(Environment.SpecialFolder.InternetCache) + "\\" + fi.Name.Replace(fi.Name, "devDelable" + rnd.Next(1, 10000000) + "_" + fi.Name);
Application.Save(tempFileName);
}
catch (Exception)
{
tempFileName = fi.FullName.Replace(fi.Name, "devDelable" + rnd.Next(1, 10000000) + "_" + fi.Name);
Application.Save(tempFileName);
}
try
{
FileInfo fTemp = new FileInfo(tempFileName);
foreach (FileInfo tmpFile in fTemp.Directory.GetFiles("devDelable*.*"))
{
tmpFile.Delete();
}
}
catch
{ }
Application.Workbooks.Close();
Application.Quit();
//Purpose: Get the process ID of the Excel instance. This is used to prevent orphaned Excel processes.
Process[] processes = Process.GetProcesses();
int processID = 0;
bool originalVisibility;
int i;
originalVisibility = Application.Visible;
Application.Visible = true;
for (i = 0; i <= processes.GetUpperBound(0); i++)
{
if (processes[i].MainWindowHandle.ToString() == Application.Hwnd.ToString())
{
processID = processes[i].Id;
break;
}
}
Application.Visible = originalVisibility;
//Purpose: Look for an Excel process matching the process id
Process process = null;
for (i = 0; i <= processes.GetUpperBound(0); i++)
{
if (processes[i].Id == processID)
{
process = processes[i];
break;
}
}
//Make sure we have a matching process
if (process != null)
{
//Make sure it is an excel process
if (process.ProcessName.ToUpper() == "EXCEL")
{
//Make sure the process has not exited
if (!process.HasExited)
{
//Make sure the process no longer has a main window.
//if (aProcess.MainWindowHandle.ToString() == "0")
process.Kill();
//else
//MessageBox.Show("Excel is still open but not longer being used by this program. You may close Excel if you are no longer using it.");
}
}
}
Application = null;
}
#endregion
#region DataSource2Array
private object[,] DataSource2Array(System.Data.DataTable datatable)
{
object[,] arrData;
arrData = new object[datatable.Rows.Count, datatable.Columns.Count];
for (int i = 0; i < datatable.Rows.Count; i++)
{
for (int j = 0; j < datatable.Columns.Count; j++)
{
arrData[i, j] = datatable.Rows[i][j];
}
}
return arrData;
}
private object[,] DataSource2Array(System.Data.DataView dataSource)
{
object[,] arrData;
int rowCount = dataSource.Count;
int colCount = dataSource.Table.Columns.Count;
arrData = new object[rowCount, colCount];
for (int i = 0; i < rowCount; i++)
{
for (int j = 0; j < colCount; j++)
{
arrData[i, j] = dataSource[i][j];
}
}
return arrData;
}
#endregion
private System.Data.DataTable Object2Datatable(object value)
{
object[,] values;
bool IsArray = value.GetType().IsArray;
if (IsArray)
{
values = (object[,])value;
return Array2Datatable(values);
}
else
{
return Array2Datatable(value);
}
}
#region Array2Datatable
private System.Data.DataTable Array2Datatable(object[,] array)
{
System.Data.DataTable dt = new System.Data.DataTable();
for (int j = 0; j < array.GetLength(1); j++)
{
dt.Columns.Add("Col" + (j+1));
}
for (int i = 0; i < array.GetLength(0) ; i++)
{
DataRow dr = dt.NewRow();
dt.Rows.Add(dr);
for (int j = 0; j < array.GetLength(1); j++)
{
dt.Rows[i][j] = array[i+1, j+1];
}
}
return dt;
}
private System.Data.DataTable Array2Datatable(object value)
{
System.Data.DataTable dt = new System.Data.DataTable();
dt.Columns.Add("Col1");
DataRow dr = dt.NewRow();
dt.Rows.Add(dr);
dt.Rows[0][0] = value;
return dt;
}
#endregion
public System.Data.DataTable GetRangeValue(int SheetIndex, string From,string To)
{
Microsoft.Office.Interop.Excel.Worksheet sheet = (Microsoft.Office.Interop.Excel.Worksheet) Workbook.Sheets[SheetIndex];
Range rng = sheet.get_Range(From, To);
Range cell;
object[,] value = (object[,]) rng.Value2;
for (int i = 0; i < rng.EntireRow.Count; i++)
{
for (int j = 0; j < rng.EntireColumn.Count; j++)
{
cell = (Range)rng.Cells[i + 1, j + 1];
}
}
return Array2Datatable(value);
}
#region SetRangeValue
public void SetRangeValue(int ColumnIndex, int RowIndex, Microsoft.Office.Interop.Excel.Worksheet sheet, System.Data.DataTable datatable, bool AutoFit)
{
object[,] data = DataSource2Array(datatable);
SetRangeValue(ColumnIndex, RowIndex, sheet, data, AutoFit);
}
public void SetRangeValue(int ColumnIndex, int RowIndex, Microsoft.Office.Interop.Excel.Worksheet sheet, System.Data.DataView dataSource, bool AutoFit)
{
object[,] data = DataSource2Array(dataSource);
SetRangeValue(ColumnIndex, RowIndex, sheet, data, AutoFit);
}
#endregion
public Microsoft.Office.Interop.Excel.Worksheet CopyToEnd(Microsoft.Office.Interop.Excel.Workbook book, int Index)
{
Worksheet source = ((Worksheet)book.Worksheets[Index]);
Worksheet lastSheet = ((Worksheet)book.Worksheets[book.Worksheets.Count]);
source.Copy(Missing.Value, lastSheet);
lastSheet = ((Worksheet)book.Worksheets[book.Worksheets.Count]);
return lastSheet;
}
#region SetRangeValue
public void SetRangeValue(int ColumnIndex, int RowIndex, Microsoft.Office.Interop.Excel.Worksheet sheet, object[,] data, bool AutoFit)
{
Range rng = sheet.get_Range(sheet.Cells[RowIndex, ColumnIndex], sheet.Cells[RowIndex + data.GetLength(0) - 1, ColumnIndex + data.GetLength(1) - 1]);
rng.Value2 = data;
if (AutoFit)
{
rng.EntireColumn.AutoFit();
}
}
#endregion
#region SetRangeValue
public void SetCellValue(int ColumnIndex, int RowIndex, Microsoft.Office.Interop.Excel.Worksheet sheet, object data)
{
sheet.get_Range(sheet.Cells[RowIndex, ColumnIndex], sheet.Cells[RowIndex, ColumnIndex]).Value2 = data;
}
public void SetCellValue(int ColumnIndex, int RowIndex, Microsoft.Office.Interop.Excel.Worksheet sheet, object data, bool AutoFit, XlHAlign HorizantalAlignment)
{
Range rng = sheet.get_Range(sheet.Cells[RowIndex, ColumnIndex], sheet.Cells[RowIndex, ColumnIndex]);
rng.Value2 = data;
rng.HorizontalAlignment = HorizantalAlignment;
if (AutoFit)
{
rng.EntireColumn.AutoFit();
}
}
#endregion
public System.Data.DataTable GetDefinedNameValue(string Name)
{
object value = workbook.Names.Item(Name, miss, miss).RefersToRange.Value2;
return Object2Datatable(value);
}
public string GetDefinedNameCellValue(string Name)
{
object value = workbook.Names.Item(Name, miss, miss).RefersToRange.Value2;
return value.ToString();
}
#region SetDefinedNameValue
public void SetDefinedNameValue(string Name, Microsoft.Office.Interop.Excel.Workbook workbook, object data)
{
workbook.Names.Item(Name, miss, miss).RefersToRange.Value2 = data;
}
public void SetDefinedNameValue(string Name, Microsoft.Office.Interop.Excel.Worksheet worksheet, object data)
{
worksheet.Names.Item(Name, miss, miss).RefersToRange.Value2 = data;
}
public void DeleteColumns(Worksheet ws, string From, string To)
{
ws.get_Range(From + ":" + From, To + ":" + To).Delete(XlDeleteShiftDirection.xlShiftToLeft);
}
public double GetSum(Worksheet ws, string From, string To)
{
Range TotalSumCell = ws.get_Range("DD1", "DD1");
TotalSumCell.FormulaLocal = "=TOPLA(" + From + ":" + To + ")";
double TotalSum = (double)TotalSumCell.Value2;
TotalSumCell.FormulaLocal = "";
return TotalSum;
}
#endregion
public void DeleteWorksheet(Workbook workbook, int Index)
{
Worksheet ws = (Worksheet)workbook.Worksheets[Index];
ws.Delete();
}
}
}