Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/18: Рейтинг темы: голосов - 18, средняя оценка - 4.83
foo();
 Аватар для rattrapper
886 / 587 / 222
Регистрация: 03.07.2013
Сообщений: 1,549
Записей в блоге: 2
.NET 4.x

Excel Interop 15, получение открытого окна

26.10.2013, 21:25. Показов 3600. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
При работе с интероп все обычно начинается с
C#
1
Excel.Application app = new Excel.Application();
, у меня появился вопрос, можно ли получить экземпляры всех открытых в екселе окон?
Если нет, то как быть, если нужный мне файл уже открыт, и нельзя потерять изменения?
Спасибо.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.10.2013, 21:25
Ответы с готовыми решениями:

Interop.Microsoft.Office.Interop.Excel, как исправить ошибку несовместимости версий
Error 1 Assembly 'Interop.Microsoft.Office.Interop.Excel, Version=1.7.0.0, Culture=neutral, PublicKeyToken=null' uses...

Работа с документами Excel без Microsoft.Office.Interop.Excel
всем добрый день все дело в том что для своих программ я использую БД Excel но! однако не все устанавливают на компьютере Office, да и...

Фоновое сканирование открытого COM-порта и получение данных
Добрый день. Сразу прошу не ругать, я в программировании полный нуль. Ну почти... Занимаюсь моддингом в свободное время и частенько...

6
 Аватар для Kruds
708 / 708 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
26.10.2013, 21:34
Здравствуйте. Доводилось порой пользоваться такой конструкцией (источник):
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
public Excel.Application StartExcel()
{
    Excel.Application instance = null;
    try
    {
       instance = (Excel.Application)System.Runtime.InteropServices.Marshal.GetActiveObject("Excel.Application");
    }
    catch (System.Runtime.InteropServices.COMException ex)
    {
       instance = new Excel.ApplicationClass();
    }
    return instance;
}
А все открытые книги, думается, можно получить из коллекции Workbooks объекта Application.
1
foo();
 Аватар для rattrapper
886 / 587 / 222
Регистрация: 03.07.2013
Сообщений: 1,549
Записей в блоге: 2
26.10.2013, 21:55  [ТС]
В принципе, проблема решена, но остался один вопрос:
Если открыто несколько окон в одном процессе Excel, метод работает, все хорошо. Но если открыто два работающих процесса, то один остается без внимания! Есть идеи, как исправить?

Не по теме:

з.ы. еще раз спасибо за ответ, Kruds, очень помог



Добавлено через 2 минуты
Пример

Этот код показывает все октрытые ранее окна, но My.xls не выводит
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
class Program
{
    static void Main(string[] args)
    {
        Excel.Application app = new Excel.Application();
        app.Visible = true;
        app.Workbooks.Open(Environment.GetFolderPath(Environment.SpecialFolder.Desktop) + "\\My.xls");
        app = (Excel.Application)System.Runtime.InteropServices.Marshal.GetActiveObject("Excel.Application");
        foreach (Excel.Workbook wb in app.Workbooks)
            Console.WriteLine(wb.FullName);
        app = new Excel.Application();
        foreach (Excel.Workbook wb in app.Workbooks)
            Console.WriteLine(" " + wb.FullName);
        Console.ReadKey();
    }
}
0
 Аватар для VirusVoronezh
1 / 1 / 0
Регистрация: 21.11.2008
Сообщений: 70
10.02.2014, 01:44
Цитата Сообщение от rattrapper Посмотреть сообщение
В принципе, проблема решена, но остался один вопрос:
Если открыто несколько окон в одном процессе Excel, метод работает, все хорошо. Но если открыто два работающих процесса, то один остается без внимания! Есть идеи, как исправить?
Нашли решение?
0
foo();
 Аватар для rattrapper
886 / 587 / 222
Регистрация: 03.07.2013
Сообщений: 1,549
Записей в блоге: 2
11.02.2014, 00:20  [ТС]
VirusVoronezh, ну можно, например, в цикле получать процесс екселя, и если в нем открыт искомый файл - использовать этот процесс, если нет - убить его, а если процессы закончатся - создать новый...
Все зависит от цели

Добавлено через 55 секунд

Не по теме:

з.ы. аватарка классная у Вас :)

0
 Аватар для VirusVoronezh
1 / 1 / 0
Регистрация: 21.11.2008
Сообщений: 70
18.02.2014, 18:57
rattrapper, пишу себе программку для работы, чтобы облегчить себе жизнь, уже весь функционал проги сделал, осталось доделать закрытие процесса принадлежащего открытому файлу! Т.к. одновременно может быть открыто несколько файлов в экселе, то надо как-то узнать, какой именно процесс нунжно завершить.

Вот тут у меня болты что-то...

Добавлено через 1 минуту
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
        //------Функция для получения id(pid) всех Excel процессов-----------------------------------------------------------------------------
        public static int[] GetExcel_Pids()
        {
            ArrayList myAL = new ArrayList();                                   //Создадим ArrayList, в нем будут храниться id-процессов (pid) уже открытых Excel-файлов
            Process[] AllProcesse = System.Diagnostics.Process.GetProcesses();  //Получим список процессов
            foreach (Process pr in AllProcesse)                                 //Переберем процессы
                if (pr.ProcessName == "EXCEL")                                  //Если процесс равен EXCEL
                    myAL.Add(pr.Id);                                            //То добавим его в список
 
            int[] myArr = (int[])myAL.ToArray(typeof(int));                     //Преобразуем список в массив из целых чисел
 
            return myArr;                                                       //Вернем полученный массив
        }
Вот таким макаром выбираю pid'ы всех процессов экселя.

Добавлено через 2 минуты
C#
1
                Microsoft.Office.Interop.Excel.Application app = (Microsoft.Office.Interop.Excel.Application)System.Runtime.InteropServices.Marshal.GetActiveObject("Excel.Application");
Вот так получаю апп, только почему-то не всегда вылавливается все открытые, дело в том, что те эксельки, которые мне нужны, они формируются сторонней писанной прогой для БДшки конторы, на выходе файл расходной накладной, название которой начинается с Reports, а дальше цифра, типа Reports1, Reports2...

Добавлено через 8 минут
И фишка ещё в том, что когда я начинаю фильтровать :

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
                Microsoft.Office.Interop.Excel.Application app = (Microsoft.Office.Interop.Excel.Application)System.Runtime.InteropServices.Marshal.GetActiveObject("Excel.Application");
 
                if (app.Workbooks.Count > 0)
                {
                    SaveExcelBook seb = new SaveExcelBook();
                    List<int> col_Excel_id = new List<int>();
 
                    // Фильтруем только файлы в названии который есть слово "Reports"
                    int i = 1;
                    foreach (Microsoft.Office.Interop.Excel.Workbook wb in app.Workbooks)
                    {
                        if (wb.Name.IndexOf("Reports") != -1)
                        {
                            seb.comboBoxExcelFiles.Items.Add(wb.Name); // wb.FullName - полный путь файла
                            col_Excel_id.Add(i);
                        }
                        i++;
                    }
То отфильтровывается только первый файл Report

Добавлено через 1 час 29 минут
Ещё вопрос, как, к примеру, узнать PID процесса Excel, который был запущен пользователем и сейчас держит открымум файл PH123.xls ??
0
Администратор
Эксперт .NET
 Аватар для tezaurismosis
9673 / 4825 / 763
Регистрация: 17.04.2012
Сообщений: 9,664
Записей в блоге: 14
18.02.2014, 19:10
Цитата Сообщение от VirusVoronezh Посмотреть сообщение
узнать PID процесса Excel, который был запущен пользователем
Не помню точно имя процесса Excel, но как-то так
C#
1
Int32 excelProcPID = Process.GetProcessesByName("winexcel")[0].Id;
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.02.2014, 19:10
Помогаю со студенческими работами здесь

Использование Interop Excel
Добрый день! Есть приложение, которое должно вносить определенные изменения в Excel файл. Ниже часть кода using System; ...

Поиск открытого окна в цикле
Не могу сделать проверку открытого окна: То есть, если окно открыто то делаем какое-либо действо, если окно не открыто то запускаем цикл...

Microsoft.Office.Interop.Excel
Доброго времени суток! Делаю гистограмму, есть код: var XL1 = new Application(); var t = Type.Missing; ...

Теория: интерфейсы (+Excel interop)
С интерфейсами знаком очень поверхностно, и хотелось бы на примере excel больше понять Почему основные &quot;средства&quot; interop...

Работа с word и excel (Interop)
Добрый вечер всем. Появился у меня вопрос по моему проекту. Написал я небольшую программку. Все работает: - программа запускается -...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru