форкнуто от main/python-labs
Вы не можете выбрать более 25 тем
Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
4.3 KiB
4.3 KiB
Общее контрольное задание по Теме 8
Кузьменко Елена, А-02-23
Задание
Разработайте программу, состоящую из трех модулей:
1) Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу.
2) Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
3) Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки.
Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы.
Решение
1) Модуль 1
# Модуль 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
# Модуль 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
# Модуль 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:
=========== RESTART: C:/Users/vaffl/Desktop/Учеба/ПОАС/TEMA8/OKZ3.py ===========
Введите имя первого файла:
task_test1.txt
Введите имя второго файла:
task_test2.txt
Коэффициент корреляции: -0.062