Форум программистов, компьютерный форум, киберфорум
C++/CLI Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/15: Рейтинг темы: голосов - 15, средняя оценка - 4.73
3 / 3 / 2
Регистрация: 22.03.2015
Сообщений: 38

Почему не работает функция Max из Excel?

04.04.2015, 10:31. Показов 3270. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет, помогите, уже голову сломал...
Сделал проект Windows Forms C++/CLI, добавил COM-объект Microsoft Excel 14.0 Object Library
На форме только dataGridView
Хочу для расчёта вызвать метод Excel, вот такой код работает:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
int height=3,width=3;
array<double,2> ^ A=gcnew array<double,2>(height,width);
for (int i=0; i<height; i++)
for (int j=0; j<width; j++) {
    A[i,j]=0;
    try {
     A[i,j] = 
         System::Double::Parse(dataGridView1->Rows[i]->Cells[j]->Value->ToString());
    } catch (...) {};
}
auto XL1 = gcnew Microsoft::Office::Interop::Excel::Application();
double  Res = XL1->Application->WorksheetFunction->MDeterm(A);
String ^ Result = "Ответ="+Convert::ToString(Res)+"\n";
MessageBox::Show(Result,"Ответ",MessageBoxButtons::OK,MessageBoxIcon::Information);
XL1->Quit();

Создается матрица и через функцию Excel считается определитель от нее
в Excel это формула типа =МОПРЕД(A1:C3)

Заменяем MDeterm например на Max - Ничего не работает

Error C2660: Microsoft::Office::Interop::Excel::Works heetFunction::Max: функция не принимает 1 аргументов
а в Exel =МАКС(A1:C3) работает отлично - это же тоже 1 аргумент
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.04.2015, 10:31
Ответы с готовыми решениями:

Не работает max-width, почему?
Не работает max-width у контейнера .two, почему? &lt;div id=&quot;wrapper&quot;&gt; &lt;div class=&quot;one&quot;&gt;&lt;/div&gt; &lt;div...

Как работает функция MAX
Делаю на sqlex задачи, 14я задача Найти производителей, которые выпускают более одной модели, при этом все выпускаемые производителем...

Почему так работает max-width
прошу в 2 словах объяснить ПОЧЕМУ так работает max-width. Вот цитата: &quot;Проблема гибких изображений решается с помощью правила img...

2
Администратор
Эксперт .NET
 Аватар для tezaurismosis
9670 / 4823 / 762
Регистрация: 17.04.2012
Сообщений: 9,661
Записей в блоге: 14
04.04.2015, 16:09
Лучший ответ Сообщение было отмечено tezaurismosis как решение

Решение

Microsoft::Office::Interop::Excel::Works heetFunction::Max принимает 30 () аргументов
WorksheetFunction.Max method
К сожалению, придётся указывать все эти аргументы. Вместо пустых нужно вписать Type::Missing.
В C# 4.0 эта проблема решена с добавление опциональных параметров и значений по-умолчанию для них, однако такой возможности в C++/CLI нет.
Есть разные ухищрения с атрибутом [Optional], можете попытаться: Optional parameters in managed C++/CLI methods
2
 Аватар для ПерС
587 / 490 / 371
Регистрация: 05.11.2013
Сообщений: 1,271
Записей в блоге: 6
05.04.2015, 07:21
Лучший ответ Сообщение было отмечено tezaurismosis как решение

Решение

не так давно тоже мучился с подобным. действительно, если сделать из кода ТС вот так, то работает
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
const int height=3,width=3;
array<double,2> ^ A=gcnew array<double,2>(height,width);
for (int i=0; i<height; i++)
for (int j=0; j<width; j++) {
 A[i,j]=0; //а лучше "минус большое число", если не хотим специально считать не-числа как нули
 try {
  A[i,j] = 
   System::Double::Parse(dataGridView1->Rows[i]->Cells[j]->Value->ToString());
 } catch (...) {};
}
auto XL1 = gcnew Microsoft::Office::Interop::Excel::Application();
double  Res = XL1->Application->WorksheetFunction->Max(A,
Type::Missing,Type::Missing,Type::Missing,Type::Missing,Type::Missing,
Type::Missing,Type::Missing,Type::Missing,Type::Missing,Type::Missing,
Type::Missing,Type::Missing,Type::Missing,Type::Missing,Type::Missing,
Type::Missing,Type::Missing,Type::Missing,Type::Missing,Type::Missing,
Type::Missing,Type::Missing,Type::Missing,Type::Missing,Type::Missing,
Type::Missing,Type::Missing,Type::Missing,Type::Missing);
String ^ Result = "Max="+Convert::ToString(Res)+"\n";
MessageBox::Show(Result,"Ответ",MessageBoxButtons::OK,MessageBoxIcon::Information);
XL1->Quit();
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.04.2015, 07:21
Помогаю со студенческими работами здесь

Почему во flex не работает max-height
Добрый день как в этом коде https://jsfiddle.net/NestGreg/h7nsgxwc/2/ добится чтобы по высоте картинке уменьшались при изменении...

Есть программа, которая должна выводить график max и min функции, но она почему то не работает
Program Graphik; uses Graph; Type T=array of real; gt=string; var Gd,Gm: integer; z1,z2,z3: byte; Procedure Grf(tc:Gt; x,y:...

Почему не работает С++ с Excel...
Почему сервер на с++ работает с клиентом, написанным на обыкновенном VB(тот свободно создает нужный объект), и не работает Excel(не видит...

Почему не работает функция?
Привет всем. Есть код: SET ifile=param.txt SET tfile=%ifile%.tmp SET find=FA_ALERT=1 SET replace=FA_ALERT=0 IF EXIST...

Почему не работает функция?
Почему не работает функция? Пишет ошибку: результатом выполнения фрагмента не является 0 аргумеетов int provPas() { string...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Ниже машинный перевод статьи The Thinkpad X220 Tablet is the best budget school laptop period . Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы,. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru