форкнуто от main/python-labs
Вы не можете выбрать более 25 тем
Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
89 строки
4.3 KiB
Markdown
89 строки
4.3 KiB
Markdown
## Общее контрольное задание по Теме 8
|
|
|
|
Кузьменко Елена, А-02-23
|
|
|
|
## Задание
|
|
|
|
Разработайте программу, состоящую из трех модулей:
|
|
1) Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу.
|
|
2) Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
|
|
3) Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки.
|
|
Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы.
|
|
|
|
## Решение
|
|
|
|
### 1) Модуль 1
|
|
|
|
```py
|
|
# Модуль 1 OKZ1.py
|
|
def file(filename):
|
|
num = []
|
|
file = open(filename, 'r')
|
|
lines = file.readlines()
|
|
file.close()
|
|
|
|
for line in lines:
|
|
line = line.strip() # удаляем пробелы и переносы в начале и конце строки
|
|
if line: # проверяем, что строка не пустая
|
|
parts = line.split()
|
|
for part in parts:
|
|
num.append(float(part)) # преобразуем часть в число и добавляем в список
|
|
|
|
return num
|
|
```
|
|
|
|
### 2) Модуль 2
|
|
|
|
```py
|
|
# Модуль 2 OKZ2.py
|
|
def corr(list1, list2):
|
|
n = len(list1) if len(list1) < len(list2) else len(list2)
|
|
if n < 2:
|
|
return 0.0
|
|
sred1 = sum(list1[:n]) / n
|
|
sred2 = sum(list2[:n]) / n
|
|
s1 = s2 = s3 = 0.0
|
|
for i in range(n):
|
|
d1 = list1[i] - sred1 # отклонение от среднего для первого списка
|
|
d2 = list2[i] - sred2 # отклонение от среднего для второго списка
|
|
s1 += d1 * d2 # сумма произведений отклонений
|
|
s2 += d1 * d1 # сумма квадратов отклонений первого
|
|
s3 += d2 * d2 # сумма квадратов отклонений второго
|
|
if s2 == 0 or s3 == 0:
|
|
return 0.0
|
|
return s1 / ((s2 * s3) ** 0.5)
|
|
```
|
|
|
|
### 3) Модуль 3
|
|
|
|
```py
|
|
# Модуль 3 OKZ3.py
|
|
import OKZ1, OKZ2
|
|
print("Введите имя первого файла:")
|
|
file1 = input()
|
|
print("Введите имя второго файла:")
|
|
file2 = input()
|
|
num1 = OKZ1.file(file1)
|
|
num2 = OKZ1.file(file2)
|
|
corr0 = OKZ2.corr(num1, num2)
|
|
corr0 = round(corr0, 3)
|
|
print("Коэффициент корреляции:", corr0)
|
|
```
|
|
|
|
### Проверка
|
|
|
|
Содержимое файла task_test1.txt:
|
|
112 45 102 8 -23 6 12.2 9 -9.2
|
|
|
|
Содержимое файла task_test2.txt:
|
|
32 -0.5 12.3 9 10 98 8 12
|
|
|
|
Запуск Модуля 3:
|
|
```py
|
|
=========== RESTART: C:/Users/vaffl/Desktop/Учеба/ПОАС/TEMA8/OKZ3.py ===========
|
|
Введите имя первого файла:
|
|
task_test1.txt
|
|
Введите имя второго файла:
|
|
task_test2.txt
|
|
Коэффициент корреляции: -0.062
|
|
``` |