Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [VBA] Пользовательская функция, с параметром диапазоном 
V
    Опции темы
termik
Дата 22.12.2006, 12:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


КотеГ
**


Профиль
Группа: Участник
Сообщений: 817
Регистрация: 20.11.2005

Репутация: нет
Всего: 33



Пользовательская функция с параметром диапазоном. Написать фунцию, которая возращает количество дней между минимальной и максимальной датой диапазона ячеек с датами (используйте обычный математический оператор разность). Напишите комментариии и сходинки пожалуйста. 


Это сообщение отредактировал(а) alexeis1 - 22.12.2006, 12:53
PM MAIL WWW ICQ   Вверх
Rodman
Дата 22.12.2006, 13:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 26
Всего: 122



termik, заглянь в инструкцию... 
PM MAIL WWW Skype GTalk YIM MSN   Вверх
Aloha
Дата 22.12.2006, 13:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


.
**


Профиль
Группа: Участник Клуба
Сообщений: 351
Регистрация: 14.5.2006

Репутация: 97
Всего: 165



termik
Код
Public Function ЧИСЛОДНЕЙ(Массив As Range)
  Dim v_MinDate, v_MaxDate        'объявляем переменные
  'присваеваем v_MinDate значение первой ячейки диапазона
  v_MinDate = Массив.Cells(1, 1)
  For Each x In Массив            'цикл по ячейкам диапазона
    'ищем значения максимальной и минимальной даты
    'если значение текущей ячейки меньше v_MinDate, то
    'v_MinDate = значению текущей ячейки
    If x < v_MinDate Then v_MinDate = x
    'если значение текущей ячейки больше v_MaxDate, то
    'v_MaxDate = значению текущей ячейки
    If x > v_MaxDate Then v_MaxDate = x
  Next
  'Возвращаемое функцией значение равно разности максимальной
  'и минимальной дат (целое число)
  ЧИСЛОДНЕЙ = CLng(v_MaxDate - v_MinDate)
End Function


Это сообщение отредактировал(а) Aloha - 27.12.2006, 14:13

Присоединённый файл ( Кол-во скачиваний: 2 )
Присоединённый файл  01_02.rar 6,54 Kb
PM   Вверх
Genyaa
Дата 22.12.2006, 14:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Усердный
*


Профиль
Группа: Участник
Сообщений: 154
Регистрация: 25.9.2006
Где: Москва

Репутация: 5
Всего: 11



Для Ексела можно сделать и так:

Код

Public Function myFunction(Массив As Range) as Long
'пользовательская функция определения разницы в днях между максимальной и минимальной датой в области ячеек, передаваемой в функцию в качестве аргумента
'
'определяем разницу между максимальным и минимальным значением, поиск которых осущестляется с помощью встроенных функций Ексела max и min
    myFunction = WorksheetFunction.Max(Массив) - WorksheetFunction.Min(Массив)
End Function

--------------------
Всякое решение плодит новые проблемы.
PM WWW   Вверх
termik
Дата 23.12.2006, 00:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


КотеГ
**


Профиль
Группа: Участник
Сообщений: 817
Регистрация: 20.11.2005

Репутация: нет
Всего: 33



Спасиб алоха получил +
PM MAIL WWW ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0821 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.