Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

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