Get UsedRange с поздним связыванием - PullRequest
0 голосов
/ 26 апреля 2011

Я пытаюсь использовать Late Binding для работы моего приложения на любом ПК с любой версией Excel.

Итак, я читал и пытался реализовать примеры, которые видел, но это так запутанно.

Я успешно создаю экземпляр и открываю файл, но как мне получить UsedRange?

Мой код:

object excelApp;
object book;
object usedrange;

excelType = Type.GetTypeFromProgID("Excel.Application");
excelApp = Activator.CreateInstance(excelType);


object docs = excelApp.GetType().InvokeMember("Workbooks",
    BindingFlags.GetProperty, null, excelApp, null);


object[] parms = { "C:\\ABC", Missing.Value, true };
book = docs.GetType().InvokeMember("Open",
    BindingFlags.InvokeMethod, null, docs, parms);


object[] params2 = { "UsedRange", Missing.Value };
usedrange = book.GetType().InvokeMember("Range",
    BindingFlags.GetProperty, null, book, params2);

И как я могу получить строку, а затем ячейку за ячейкой?

Заранее спасибо!

Ответы [ 2 ]

1 голос
/ 28 апреля 2011

Попробуйте LateBindingApi.Excel: http://excel.codeplex.com

Тот же синтаксис, что и при раннем связывании, но с поздним связыванием.

0 голосов
/ 26 апреля 2011

Используйте Excel.Interop API.Пример здесь: http://www.dotnetperls.com/excel.

...