I have an Excel file with one column which is filled with numbers. I would like to be read the numbers from this column into an array in C#. How can 开发者_如何学GoI do that?
The easiest way is probably to use the Excel ODBC driver. This allows you to use OdbcConnection to read the worksheet into a DataTable. You can then iterate over the table's Rows collection, copying the values into a list or array.
You can use Excel Interop and do something along the lines of:
Excel.Range firstCell = excelWorksheet.get_Range("A1", Type.Missing);
Excel.Range lastCell = excelWorksheet.get_Range("A10", Type.Missing);
Excel.Range worksheetCells = excelWorksheet.get_Range(firstCell, lastCell);
var cellValues = worksheetCells.Value2;
You should get an array of objects (1-based index), and can cast the contents using (for instance) Convert.ToDouble().
SpreadsheetGear for .NET can do it. Below is some C# source. Note that the SpreadsheetGear API is similar to the Excel API, so the code below could be adapted to Excel.
using System;
using SpreadsheetGear;
namespace Program
{
    class Program
    {
        static void Main(string[] args)
        {
            // Load a workbook from disk and get the first worksheet.
            var workbook = SpreadsheetGear.Factory.GetWorkbook(@"C:\tmp\Numbers.xlsx");
            // Allocate a list of doubles to store the number.
            var numbers = new System.Collections.Generic.List<double>();
            var worksheet = workbook.Worksheets[0];
            // Assuming that column A is the column with the numbers...
            var columnA = worksheet.Cells["A:A"];
            var usedRange = worksheet.UsedRange;
            // Limit the cells we look at to the used range of the sheet.
            var numberCells = usedRange.Intersect(columnA);
            // Get the numbers into the list.
            foreach (IRange cell in numberCells)
            {
                object val = cell.Value;
                if (val is double)
                    numbers.Add((double)val);
            }
            // Write the numbers to the console.
            foreach (double number in numbers)
                Console.WriteLine("number={0}", number);
        }
    }
}
You can download the free SpreadsheetGear trial here if you want to try it yourself.
Disclaimer: I own SpreadsheetGear LLC
 
         
                                         
                                         
                                         
                                        ![Interactive visualization of a graph in python [closed]](https://www.devze.com/res/2023/04-10/09/92d32fe8c0d22fb96bd6f6e8b7d1f457.gif) 
                                         
                                         
                                         
                                         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论