From d6a0c936e01d8d0bd5795c72dee65232edc5993c Mon Sep 17 00:00:00 2001 From: EfimovaLA Date: Fri, 5 Dec 2025 00:05:00 +0000 Subject: [PATCH] =?UTF-8?q?=D0=B4=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=D0=BE=20=D0=9E=D0=9A=D0=97=20=D0=BF=D0=BE=20=D1=82=D0=B5?= =?UTF-8?q?=D0=BC=D0=B5=208?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- TEMA8/Modul1.py | 7 +++++++ TEMA8/Modul2.py | 7 +++++++ TEMA8/Modul3.py | 8 +++++++ TEMA8/task8.md | 55 +++++++++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 77 insertions(+) create mode 100644 TEMA8/Modul1.py create mode 100644 TEMA8/Modul2.py create mode 100644 TEMA8/Modul3.py create mode 100644 TEMA8/task8.md diff --git a/TEMA8/Modul1.py b/TEMA8/Modul1.py new file mode 100644 index 0000000..03273c6 --- /dev/null +++ b/TEMA8/Modul1.py @@ -0,0 +1,7 @@ +def read(name): + nums = [] + fp=open(name) + for i in fp: + for y in i.strip().split(): + nums.append(float(y)) + return nums diff --git a/TEMA8/Modul2.py b/TEMA8/Modul2.py new file mode 100644 index 0000000..10ef319 --- /dev/null +++ b/TEMA8/Modul2.py @@ -0,0 +1,7 @@ +import statistics +def corel(lst1, lst2): + n=min(len(lst1), len(lst2)) + lst1=lst1[:n] + lst2=lst2[:n] + res=statistics.correlation(lst1, lst2) + return res diff --git a/TEMA8/Modul3.py b/TEMA8/Modul3.py new file mode 100644 index 0000000..a6d1e3a --- /dev/null +++ b/TEMA8/Modul3.py @@ -0,0 +1,8 @@ +import Modul1, Modul2 +x=input('Введите название файла 1: ') +y=input('Введите название файла 2: ') +file1 = Modul1.read(x) +file2 = Modul1.read(y) +res = Modul2.corel(file1, file2) +print(res) +print('Коэффициент корреляции: ', round(res, 3)) diff --git a/TEMA8/task8.md b/TEMA8/task8.md new file mode 100644 index 0000000..b04852c --- /dev/null +++ b/TEMA8/task8.md @@ -0,0 +1,55 @@ +# Общее контрольное задание по теме 8 +Ефимова Людмила, А-03-23 + +Разработайте программу, состоящую из трех модулей: +- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным +именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько +на строке с разделением пробелом. Числа элементов в строках могут быть разными. +Полученный список должен возвращаться в вызывающую программу. + +```py +def read(name): + nums = [] + fp=open(name) + for i in fp: + for y in i.strip().split(): + nums.append(float(y)) + return nums +``` +- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам +(аргументы функции – имена двух списков). Числа элементов в списках могут различаться. +Значение коэффициента должно возвращаться в вызывающую программу. + +```py +import statistics +def corel(lst1, lst2): + n=min(len(lst1), len(lst2)) + lst1=lst1[:n] + lst2=lst2[:n] + res=statistics.correlation(lst1, lst2) + return res +``` +- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, +дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. +Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 +и отображает рассчитанное значение на экране с округлением до трех цифр после точки. +Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы. +```py +import Modul1, Modul2 +x=input('Введите название файла 1: ') +y=input('Введите название файла 2: ') +file1 = Modul1.read(x) +file2 = Modul1.read(y) +res = Modul2.corel(file1, file2) +print(res) +print('Коэффициент корреляции: ', round(res, 3)) +``` +Проверка + +```py +import Modul3 +Введите название файла 1: sps.txt +Введите название файла 2: sps2.txt +0.9970501410659874 +Коэффициент корреляции: 0.997 +``` \ No newline at end of file