Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RusFAQ.ru: Программирование на Basic / VBA


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

РАССЫЛКИ ПОРТАЛА RUSFAQ.RU

Чемпионы рейтинга экспертов в этой рассылке

Megaloman
Статус: Практикант
Рейтинг: 40
∙ повысить рейтинг >>
Архипов Александр Леонидович
Статус: Практикант
Рейтинг: 20
∙ повысить рейтинг >>
Шичко Игорь
Статус: Практикант
Рейтинг: 20
∙ повысить рейтинг >>

/ КОМПЬЮТЕРЫ И ПО / Языки программирования / Basic/VBA

Выпуск № 860
от 14.02.2009, 01:35

Администратор:Калашников О.А.
В рассылке:Подписчиков: 277, Экспертов: 22
В номере:Вопросов: 1, Ответов: 2

Нам важно Ваше мнение об этой рассылке.
Оценить этот выпуск рассылки >>

Вопрос № 159917: Здравствуйте! У меня проблема: мне надо узнать размер файла, а у больших файлов (>1Гб) функция FileLen находит его неправильно, она часто выводит отрицательное значение. Скажите, пожалуйста, как еще можно узнать размер файла? Я программирую ...


Вопрос № 159.917
Здравствуйте!
У меня проблема: мне надо узнать размер файла, а у больших файлов (>1Гб) функция FileLen находит его неправильно, она часто выводит отрицательное значение. Скажите, пожалуйста, как еще можно узнать размер файла?
Я программирую на VB6 (Visual Basic 6).
ОЧЕНЬ надеюсь на помощь! Большое спасибо!
Отправлен: 08.02.2009, 12:18
Вопрос задал: AkaProc (статус: 4-й класс)
Всего ответов: 2
Мини-форум вопроса >>> (сообщений: 3)

Отвечает: Megaloman
Здравствуйте, AkaProc! Не программирую в VB6. Для VBA нашел описание функции
© Цитата: В справке по VBA прочел:
FileLen Function
Returns a Long specifying the length of a file in bytes.

Long data type
A 4-byte integer ranging in value from -2,147,483,648 to 2,147,483,647.
The ampersand (&) type-declaration character represents a Long in Visual Basic.
Тут четко указано, что FileLen правильно может вернуть значение не более 2,147,483,647
Повторюсь: Не программирую в VB6, под руками нет ни литературы, ни хелпов.
Наверное, можно поискать другую функцию, возвращающую не Long, a Double (если и в самом деле в VB6 функция FileLen возвращает значение Long, а не просто у Вас ошибка - пыта етесь значение функции присвоить переменной типа не Double).
© Цитата: В справке по VBA прочел:
Double data type
A data type that holds double-precision floating-point numbers as 64-bit numbers
in the range -1.79769313486231E308 to -4.94065645841247E-324 for negative values;
4.94065645841247E-324 to 1.79769313486232E308 for positive values.
The number sign (#) type-declaration character represents the Double
Вашу проблему решил другим путём:
Код:
Dim Z1 As Double,
  Z2 As Double

MyFile1 = "W:MOV01970.MPG"
MyFile2 = "E:Virtual.CDPainting_Big.iso"

Set FSO = CreateObject("Scripting.FileSystemObject")

Set File1 = FSO.GetFile(MyFile1)
Z1 = File1.Size

Set File2 = FSO.GetFile(MyFile2)
Z2 = File2.Size
В результате работы этого кода получил правильные значения
Z1 = 1 287 071 917
Z2 = 4 603 215 872
(пробелы в число вставил для читаемости)

Надеюсь этот способ получится и у Вас, разве что придётся добавить описания типов в Dim

---------
Нет времени на медленные танцы
Ответ отправил: Megaloman (статус: Практикант)
Ответ отправлен: 08.02.2009, 17:52

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 243178 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!

    Оценка за ответ: 5
    Комментарий оценки:
    ОГРОМНОЕ СПАСИБО!!!
    У меня все заработало!


    Отвечает: Тесленко Евгений Алексеевич
    Здравствуйте, AkaProc!
    Код:
    Sub fileSize()
    Debug.Print Format(iLenFile("E:DisksFileImage.nrg"), "#,##0")
    End Sub
    Function iLenFile(sFileName$) As Double
    Dim FSO, f
    Set FSO = CreateObject("Scripting.FileSystemObject")
    Set f = FSO.GetFile(sFileName)
    iLenFile = FSO.GetFile(sFileName).Size
    Set FSO = Nothing
    End Function
    Ответ отправил: Тесленко Евгений Алексеевич (статус: Практикант)
    Ответ отправлен: 08.02.2009, 20:18

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 243185 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!

    Оценка за ответ: 5
    Комментарий оценки:
    Спасибо!


    Вы имеете возможность оценить этот выпуск рассылки.
    Нам очень важно Ваше мнение!
    Оценить этот выпуск рассылки >>

    Отправить вопрос экспертам этой рассылки

    Приложение (если необходимо):

    * Код программы, выдержки из закона и т.п. дополнение к вопросу.
    Эта информация будет отображена в аналогичном окне как есть.

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

    Для того, чтобы отправить вопрос выбранным экспертам этой рассылки или
    экспертам другой рассылки портала RusFAQ.ru, зайдите непосредственно на RusFAQ.ru.


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2009, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.13 от 01.12.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное