2
Answers

how to convert Object in COM(cell value in excel) to a type Double(c#)...Still Problem...

yamid

yamid

15y
13.8k
1

I tried to convert the cell value to double (double x = Convert.ToDouble(oSheet.Cells.Cells[1, 1]);) but there is an error:

how it is possible to convert the cell value obtained from excel to Double?

I tried to put the cell value in other variable : Object X, then to convert X to double , but still the error below persisit

Unable to cast COM object of type 'System.__ComObject' to interface type 'System.IConvertible'. This operation failed because the QueryInterface call on the COM component for the interface with IID '{805E3B62-B5E9-393D-8941-377D8BF4556B}' failed due to the following error: No such interface supported (Exception from HRESULT: 0x80004002 (E_NOINTERFACE)).

 

 

_________________________________________________________

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Reflection;

using Microsoft.Office.Interop.Excel;

namespace ConsoleApplication1

{

class Program

{

static ApplicationClass App;

static Workbooks oBooks;

static Workbook oBook;

static Worksheet oSheet;

static void Main(string[] args)

{

App = null;

oBooks = null;

oBook = null;

oSheet = null;

Console.WriteLine("Enter the Excel file path");

string filepath = Console.ReadLine();

App = new ApplicationClass();

App.Visible = true;

oBooks = App.Workbooks;

//Open a new workbook

oBook = oBooks.Open(filepath,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value,

Missing.Value);

oSheet = (Worksheet)App.ActiveSheet;

/* After that you can get your cells either by

* range */

Range myRange = oSheet.get_Range("A1", "C3");

//Or by cell

double x = Convert.ToDouble(oSheet.Cells.Cells[1, 1]);

Console.WriteLine(x);

//You can get or create another sheet and transmit the content

if (App.Worksheets[2] != null)

{

Worksheet oSheet2 = App.Worksheets[2] as Worksheet;

oSheet2.Cells.Cells[1, 1] = oSheet.Cells.Cells[1, 1];

}

oBook.Save();

App.Quit();

System.Runtime.InteropServices.Marshal.ReleaseComObject(App);

App = null;

}

}

}

Answers (2)