Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
 Аватар для РегинаРегина
0 / 0 / 0
Регистрация: 14.06.2013
Сообщений: 21

Найти среднее значение из данных в файле data.txt

16.06.2013, 18:02. Показов 1512. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Мне дан текстовый файл data.txt с 4 показаниями по каждому из 3х датчиков. необходимо разработать программу, которая рассчитывала бы среднее значение по каждому показателю в течении всего времени.

Что делать после открытия файла data.txt?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.06.2013, 18:02
Ответы с готовыми решениями:

Найти в файле data.txt максимальное число и вывести в консоль
в текстовом файле data.txt записано произвольное количество вещественных чисел через пробел. Написать программу, которая находит...

Найти среднее арифметическое целых чисел, записанных в файле input.txt в столбик
Вот задача: Найти среднее арифметическое целых чисел, записанных в файле input.txt в столбик. Количество чисел неизвестно. Результат...

Найти строки в txt файле и заменить их на значение из массива
Имеется заданный в php массив: $a=Array ('текст0', 'текст1', 'текст2', 'текст3', 'текст4'); Имеется file.txt без пробелов:...

10
Модератор
10046 / 3892 / 883
Регистрация: 22.02.2013
Сообщений: 5,846
Записей в блоге: 79
16.06.2013, 18:08
В каком виде записаны данные?
0
 Аватар для РегинаРегина
0 / 0 / 0
Регистрация: 14.06.2013
Сообщений: 21
16.06.2013, 18:12  [ТС]
1.42,1.43,1.44
2.34,2.31,2.53
3.31,3.67,3.54
4.35,4.72,4.33

вот в таком, только цифры другие
0
 Аватар для morgann55
1365 / 207 / 37
Регистрация: 09.02.2012
Сообщений: 745
16.06.2013, 18:41
Лучший ответ Сообщение было отмечено The trick как решение

Решение

Создай двумерный массив (3,4), введи в него данные из файла... Потом перебери ЭТОТ массив, сложи показания каждого датчика (по строкам из 4-х показаний) и найди среднее арифметическое... (вроде понятно изложил)
2
 Аватар для РегинаРегина
0 / 0 / 0
Регистрация: 14.06.2013
Сообщений: 21
16.06.2013, 19:02  [ТС]
СПАСИБО) Второй раз мне уже помогаете!!!!!!!
0
 Аватар для morgann55
1365 / 207 / 37
Регистрация: 09.02.2012
Сообщений: 745
16.06.2013, 19:36
Цитата Сообщение от РегинаРегина Посмотреть сообщение
СПАСИБО) Второй раз мне уже помогаете!!!!!!!
Региночка, это моя прямая обязанность как более старшего (и более опытного) члена сообщества (Диалектика)
2
Модератор
10046 / 3892 / 883
Регистрация: 22.02.2013
Сообщений: 5,846
Записей в блоге: 79
16.06.2013, 19:57
Лучший ответ Сообщение было отмечено The trick как решение

Решение

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
Option Explicit
 
Private Sub Form_Load()
    Dim Fnum As Integer, S As String, F As Long, oF As Long
    Dim iD As Long, V As Single, Vs As String, Ct As Long, Dat() As Single
    Fnum = FreeFile
    Open "D:\Temp\Data.txt" For Input As Fnum
    ReDim Dat(2)
    Do Until EOF(Fnum)
        Line Input #Fnum, S
        iD = 0: oF = 1
        Do
            F = InStr(oF, S, ",")
            If F Then Vs = (Mid$(S, oF, F - oF)) Else _
                  Vs = (Mid$(S, oF))
            V = Replace(Vs, ".", ","): Vs = CSng(V)
            Dat(iD) = Dat(iD) + V
            oF = F + 1: iD = iD + 1
        Loop While F
        Ct = Ct + 1
    Loop
    Close Fnum
    Dat(0) = Dat(0) / Ct: Dat(1) = Dat(1) / Ct: Dat(2) = Dat(2) / Ct
    MsgBox "1 датчик :" & Format(Dat(0), "##0.00") & vbNewLine & _
           "2 датчик :" & Format(Dat(1), "##0.00") & vbNewLine & _
           "3 датчик :" & Format(Dat(2), "##0.00")
End Sub
1
 Аватар для РегинаРегина
0 / 0 / 0
Регистрация: 14.06.2013
Сообщений: 21
17.06.2013, 22:43  [ТС]
Cпасибо!!!!!!!!!!!!!!

Добавлено через 36 минут
Извините, что снова с вопросами. Но мне нужно разобраться в данном коде и я не понимаю:

1. Почему в строке "ReDim Dat(2)" присваиваем именно 2?
2. Почему в строке "If F Then Vs = (Mid$(S, oF, F - oF)) Else _" отнимаем (F - oF)? и еще, что значит If f (если такое f существует или что, я сталкивалась только с теми циклами где в if выражение стоит?)?
3. Почему цикл с постусловием?

если честно, совсем не разобралась, что происходит в цикле с Loop While F. Если есть время, пожалуйста объясните
0
Модератор
10046 / 3892 / 883
Регистрация: 22.02.2013
Сообщений: 5,846
Записей в блоге: 79
17.06.2013, 23:21
Цитата Сообщение от РегинаРегина Посмотреть сообщение
1. Почему в строке "ReDim Dat(2)" присваиваем именно 2?
Потому что индексация от нуля: 0,1,2 - получается 3.
Цитата Сообщение от РегинаРегина Посмотреть сообщение
2. Почему в строке "If F Then Vs = (Mid$(S, oF, F - oF)) Else _" отнимаем (F - oF)? и еще, что значит If f (если такое f существует или что, я сталкивалась только с теми циклами где в if выражение стоит?)?
Отнимаем для того чтобы найти число между запятыми. If f обозначает что условие истинно при f<>0
Цитата Сообщение от РегинаРегина Посмотреть сообщение
3. Почему цикл с постусловием?
Потому что в строке может быть один или более чисел.
2
 Аватар для РегинаРегина
0 / 0 / 0
Регистрация: 14.06.2013
Сообщений: 21
17.06.2013, 23:38  [ТС]
Еще раз СПАСИБО)
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38161 / 21096 / 4306
Регистрация: 12.02.2012
Сообщений: 34,683
Записей в блоге: 14
18.06.2013, 12:32
Лучший ответ Сообщение было отмечено The trick как решение

Решение

Я бы сделал так:

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
Sub AvrDat(fname As String)
Dim S(0 To 3) As Double
    fi% = FreeFile
    Open fname For Input As #fi%
    n# = 0
    Do While Not EOF(fi%)
       Line Input #fi%, Stri$
       Stri$ = Trim$(Stri$)
       If Len(Stri$) > 0 Then
          V = Split(Stri$, ",")
          For i% = 0 To 3
              S(i%) = S(i%) + Val(CStr(V(i%)))
          Next i%
          n# = n# + 1
       End If
     Loop
     Close #fi%
     For i% = 0 To 3
         Debug.Print "Ср-"; i% + 1; " ="; S(i%) / n#
     Next i%
End Sub
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.06.2013, 12:32
Помогаю со студенческими работами здесь

Найти среднее значение и среднее отклонение для элементов данных линейных массивов X (n), Y (m)
Найти среднее значение и среднее отклонение для элементов данных линейных массивов X(n),Y(m). Выполнить с использованием процедуры.

В файле посчитать количество элементов, и найти их среднее значение
В файле данных 7,6,4,3,2,1,0,14,8,19,41,105 посчитать количество элементов, и найты их среднее значение. Добавлено через 15 часов 17...

Загрузка Данных Из Txt (.*data)
Всем доброго времени суток! Как можно осуществить загрузку из текстового файла в 1С 8.2 (Бух), Необходимо сравнение полей контрагентов и...

В текстовом файле найти среднее значение цены и показать строки цена которых выше средней в 3 раза
В текстовом файле найти среднее значение цены и показать строки цена которых выше средней в 3 раза. Запись в ТХТ производится следующим...

В текстовом файле, состоящем из <=50 чисел, найти среднее значение квадратов и номера всех положительных элементов файла
Пожалуйста помогите: В текстовом файле, состоящем из &lt;=50 чисел, найти среднее значение квадратов и номера всех положительных элементов...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
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 - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru