Сравнить коммиты
77 Коммитов
|
После Ширина: | Высота: | Размер: 2.4 KiB |
|
После Ширина: | Высота: | Размер: 32 KiB |
|
После Ширина: | Высота: | Размер: 14 KiB |
|
После Ширина: | Высота: | Размер: 5.5 KiB |
|
После Ширина: | Высота: | Размер: 23 KiB |
|
После Ширина: | Высота: | Размер: 28 KiB |
|
После Ширина: | Высота: | Размер: 48 KiB |
|
После Ширина: | Высота: | Размер: 49 KiB |
@ -0,0 +1,6 @@
|
||||
#Программа по Теме 1 Ефимова Людмила Алексеевна
|
||||
print('Hello')
|
||||
h=input('Your name=')
|
||||
import os
|
||||
os.chdir('C:\\Users\\u207-03\\Desktop\\ПОАС\\python-labs\\TEMA1\\report')
|
||||
|
||||
@ -0,0 +1,88 @@
|
||||
# Отчет по теме 1
|
||||
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## 1 Изучение среды IDLE
|
||||
|
||||
## 1.1 Знакомство с Python 3.4 (command line)
|
||||
|
||||
```
|
||||
>>> print('Hello')
|
||||
Hello
|
||||
>>> h=input('Your name=')
|
||||
Your name=Lyudmila
|
||||
```
|
||||

|
||||
|
||||
## 1.2 Изучение графической оболочки IDLE
|
||||
|
||||
```
|
||||
import os
|
||||
os.chdir('C:\\Users\\u207-03\\Desktop\\ПОАС\\python-labs\\TEMA1\\report')
|
||||
```
|
||||
Скриншоты настройки среды.
|
||||

|
||||

|
||||
|
||||
## 1.3 Создание программы по пунктам 3,4,8:
|
||||
Создан файл pr0:
|
||||
|
||||
```
|
||||
#Программа по Теме 1 Ефимова Людмила Алексеевна
|
||||
print('Hello')
|
||||
h=input('Your name=')
|
||||
import os
|
||||
os.chdir('C:\\Users\\u207-03\\Desktop\\ПОАС\\python-labs\\TEMA1\\report')
|
||||
```
|
||||
Вывод программы:
|
||||
|
||||
```
|
||||
================== RESTART: C:\Users\u207-03\Desktop\ПОАС\python-labs\TEMA1\report\pr0.py ==================
|
||||
Hello
|
||||
Your name=Ludmila
|
||||
```
|
||||
|
||||
## 1.4 Проверка программы prb1:
|
||||
|
||||
```
|
||||
import prb1
|
||||
Как Вас зовут? Людмила
|
||||
Привет, Людмила
|
||||
```
|
||||
|
||||
## 1.5 Изучение каталога __pycache__
|
||||
|
||||
Открыла каталог и запустила в текстовом редакторе файл pr0.cpython-311.pyc:
|
||||
|
||||

|
||||
|
||||
Данный файл нужен для исполнения кода виртуальной машиной python.
|
||||
Файл расширения .pyc это скомпилированный файл для изначального кода. В нем содержится кеш выполнения программы
|
||||
|
||||
## 1.6 Изучение команды help
|
||||
|
||||
В среде пограммирования введены команды help(print) и help(input)
|
||||
|
||||

|
||||
|
||||
Получили вывод - инструкции по работе с командами.
|
||||
|
||||
## 1.7 Выполнение функции 15
|
||||
|
||||
В редакторе открыла файл prb1 и запустила его.
|
||||
Получен вывод:
|
||||
|
||||
```
|
||||
============== RESTART: C:\Users\u207-03\Desktop\ПОАС\python-labs\TEMA1\report\prb1.py =============
|
||||
Как Вас зовут? Людмила
|
||||
Привет, Людмила
|
||||
```
|
||||
|
||||
Открыт файл tdemo_chaos, изучено его содержимое.
|
||||

|
||||
|
||||
После запуска получен вывод программы:
|
||||

|
||||
|
||||
Запущен пример программы Часы (Clock) из пакета Turtle:
|
||||

|
||||
@ -0,0 +1,51 @@
|
||||
# Общее контрольное задание по теме 2
|
||||
Ефимова Людмила Алексеевна, А-03-23
|
||||
|
||||
## Задание
|
||||
Реализовать, записать в текстовый файл и проанализировать результаты последовательности инструкций, выполняющих следующие действия: • Создать переменную с именем familia и со значением - символьной строкой – своей фамилией в латинской транскрипции.
|
||||
|
||||
• Создать переменную со значением, совпадающим с первой буквой из familia.
|
||||
|
||||
• Создать переменную с именем sp_kw со значением – списком всей ключевых слов языка Python.
|
||||
|
||||
• Удалите из списка sp_kw значение 'nonlocal'. Выводом списка в командном окне IDLE убедитесь, что это значение удалено из списка.
|
||||
|
||||
• Создайте кортеж kort_nam с именами: вашим и еще 3-х студентов из вашей группы. Напишите инструкцию, позволяющую убедиться, что тип переменной – это tuple.
|
||||
|
||||
• Напишите инструкцию, добавляющую в kort_nam имена еще двух студентов.
|
||||
|
||||
• Напишите инструкцию, позволяющую определить, сколько раз в кортеже присутствуют студенты с именем «Дима».
|
||||
|
||||
• Создайте словарь dict_bas, в котором ключами являются русские названия типов переменных, использованных в предыдущих операторах, а значениями – ранее созданные переменные, соответствующие этим типам.
|
||||
|
||||
## Решение
|
||||
|
||||
```py
|
||||
familia = "Efimova"
|
||||
first = familia[0] # значение первая буква из familia
|
||||
first
|
||||
'E'
|
||||
|
||||
import keyword
|
||||
sp_kw = keyword.kwlist # значение список всех ключевых слов языка
|
||||
sp_kw
|
||||
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
|
||||
|
||||
sp_kw.remove("nonlocal") # удаляем элемент nonlocal
|
||||
sp_kw
|
||||
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
|
||||
|
||||
kort_nam = ("Lyudmila", "Maria", "Danil", "Dima")
|
||||
type(kort_nam)
|
||||
<class 'tuple'>
|
||||
|
||||
kort_nam += ("Artem", "Ilya")
|
||||
kort_nam
|
||||
('Lyudmila', 'Maria', 'Danil', 'Dima', 'Artem', 'Ilya')
|
||||
kort_nam.count("Dima")
|
||||
1
|
||||
|
||||
dict_bas = {'строка' : familia, 'список' : sp_kw, 'кортеж' : kort_nam} # создаем словарь
|
||||
dict_bas
|
||||
{'строка': 'Efimova', 'список': ['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield'], 'кортеж': ('Lyudmila', 'Maria', 'Danil', 'Dima', 'Artem', 'Ilya')}
|
||||
```
|
||||
@ -0,0 +1,22 @@
|
||||
# Индивидуальное контрольное задание
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## Задание вариант 17
|
||||
Создайте два списка: один – с фамилиями 3-х студентов вашей группы, другой – с 5 числами: 11,12,13,14,15.
|
||||
|
||||
Напишите инструкцию создания словаря, в котором фамилии студентов были бы ключами, а числа – значениями.
|
||||
|
||||
Отобразите получившийся словарь.
|
||||
|
||||
Отобразите его ключи с упорядочением по фамилиям студентов.
|
||||
|
||||
## Решение
|
||||
```py
|
||||
familii = ['Ефимова', 'Девятова','Беженарь']
|
||||
num = [11, 12, 13, 14, 15]
|
||||
dic = dict(zip(familii, num))
|
||||
print(dic)
|
||||
{'Ефимова': 11, 'Девятова': 12, 'Беженарь': 13}
|
||||
sorted(dic.keys())
|
||||
['Беженарь', 'Девятова', 'Ефимова']
|
||||
```
|
||||
@ -0,0 +1,664 @@
|
||||
# Отчет по теме 3
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## 1. Запустила оболочку IDLE, создала рабочий протокол
|
||||
|
||||
## 2. Преобразование простых базовых типов объектов
|
||||
### 2.1. Преобразовали объекты в логческий тип
|
||||
|
||||
```py
|
||||
logiz1=bool(56) # целые числа, кроме 0, преобразуются в True
|
||||
print(logiz1, ' ', type(logiz1))
|
||||
True <class 'bool'>
|
||||
logiz2=bool(0) # 0 преобразуется в False
|
||||
print(logiz2, ' ', type(logiz2))
|
||||
False <class 'bool'>
|
||||
logiz3=bool("Beta") # не пустая строка преобразуется в True
|
||||
print(logiz3, ' ', type(logiz3))
|
||||
True <class 'bool'>
|
||||
logiz4=bool("") # пустая строка преобразуется в False
|
||||
print(logiz4, ' ', type(logiz4))
|
||||
False <class 'bool'>
|
||||
```
|
||||
|
||||
### 2.2. Преобразование в целое десятичное число
|
||||
|
||||
Функция int(<Объект>[,<Система счисления, в которой определен
|
||||
объект>]) позволяет преобразовать объект в целое десятичное число
|
||||
|
||||
```py
|
||||
tt1=int(198.6) #Отбрасывается дробная частьtt1
|
||||
198
|
||||
tt2=int("-76") #Число – в строке символов, система по умолчанию - десятичная
|
||||
tt2
|
||||
-76
|
||||
tt3=int("B",16)
|
||||
tt3
|
||||
11
|
||||
tt4=int("71",8)
|
||||
tt4
|
||||
57
|
||||
tt5=int("98.76") # Число передающееся в виде строки должно быть целым
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#28>", line 1, in <module>
|
||||
tt5=int("98.76")
|
||||
ValueError: invalid literal for int() with base 10: '98.76'
|
||||
```
|
||||
С помощью функции float(<Объект>) преобразуем объекты в вещественное число
|
||||
|
||||
```py
|
||||
flt1=float(789)
|
||||
flt1
|
||||
789.0
|
||||
flt2=float(-6.78e2)
|
||||
flt2
|
||||
-678.0
|
||||
flt3=float("Infinity")
|
||||
flt3
|
||||
inf
|
||||
flt4=float("-inf")
|
||||
flt4
|
||||
-inf
|
||||
```
|
||||
|
||||
### 2.3. Преобразование десятичных чисел в другие системы счисления
|
||||
С помощью команд bin oct hex преобразовали объекты в строку с двоичным, вомьмеричным, шестнадцатиричным
|
||||
представлениями. С помощью команды int() сделали обратные преобразования.
|
||||
```py
|
||||
hh=123
|
||||
dv1=bin(hh) #Преобразование в строку с двоичным представлением
|
||||
dv1
|
||||
'0b1111011'
|
||||
vos1=oct(hh) # Преобразование в строку с восьмеричным представлением
|
||||
vos1
|
||||
'0o173'
|
||||
shs1=hex(hh) # Преобразование в строку с шестнадцатеричным представлением
|
||||
shs1
|
||||
'0x7b'
|
||||
int(dv1, 2)
|
||||
123
|
||||
int(vos1, 8)
|
||||
123
|
||||
int(shs1, 16)
|
||||
123
|
||||
```
|
||||
|
||||
## 3. Преобразование более сложных элементов
|
||||
### 3.1. Преобразование в строку символов
|
||||
|
||||
Преобразовали объект в строку функцией str(<Объект>)
|
||||
|
||||
```py
|
||||
strk1=str(23.6)
|
||||
strk1
|
||||
'23.6'
|
||||
strk2=str(logiz3)
|
||||
strk2
|
||||
'True'
|
||||
strk3=str(["A","B","C"]) #Преобразуем список
|
||||
strk3
|
||||
"['A', 'B', 'C']"
|
||||
strk4=str(("A","B","C")) #Преобразуем кортеж
|
||||
strk4
|
||||
"('A', 'B', 'C')"
|
||||
strk5=str({"A":1,"B":2,"C":9}) #Преобразуем словарь
|
||||
strk5
|
||||
"{'A': 1, 'B': 2, 'C': 9}"
|
||||
```
|
||||
### 3.2. Преобразование объектов в список
|
||||
|
||||
Преобразовали объекты в список функцией list(<Объект>).
|
||||
|
||||
```py
|
||||
spis1=list("Строка символов") #Заданная строка разделяется на символы
|
||||
spis1
|
||||
['С', 'т', 'р', 'о', 'к', 'а', ' ', 'с', 'и', 'м', 'в', 'о', 'л', 'о', 'в']
|
||||
spis2=list((124,236,-15,908)) #Кортеж превращается в список
|
||||
spis2
|
||||
[124, 236, -15, 908]
|
||||
spis3=list({"A":1,"B":2,"C":9}) #Преобразование словаря в список
|
||||
spis3
|
||||
['A', 'B', 'C']
|
||||
spis4=list({"A":1, "B":2, "C":9}.values()) #Преобразование значений в список
|
||||
spis4
|
||||
[1, 2, 9]
|
||||
spis5=list({"A":1,"B":2,"C":9}.items()) #Преобразование и ключей и значений в список
|
||||
spis5
|
||||
[('A', 1), ('B', 2), ('C', 9)]
|
||||
```
|
||||
### 3.3. Преобразование элементов объектов в кортеж
|
||||
|
||||
Преобразуем объекты в кортеж функцией tuple(<Объект>).
|
||||
|
||||
```py
|
||||
kort7=tuple('Строка символов') #Преобразование строки символов в кортеж
|
||||
kort7
|
||||
('С', 'т', 'р', 'о', 'к', 'а', ' ', 'с', 'и', 'м', 'в', 'о', 'л', 'о', 'в')
|
||||
kort8=tuple(spis2) #Преобразование списка в кортеж
|
||||
kort8
|
||||
(124, 236, -15, 908)
|
||||
kort9=tuple({"A":1,"B":2,"C":9}) #Преобразование словаря в кортеж
|
||||
kort9
|
||||
('A', 'B', 'C')
|
||||
```
|
||||
|
||||
### 3.4. Удаление объектов
|
||||
|
||||
С помощью функции del можно удалить объекты из оперативной памяти
|
||||
```py
|
||||
del strk5, kort8
|
||||
dir()
|
||||
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'dv1', 'flt1', 'flt2', 'flt3', 'flt4', 'hh', 'kort7', 'kort9', 'logiz1', 'logiz2', 'logiz3', 'logiz4', 'shs1', 'spis1', 'spis2', 'spis3', 'spis4', 'spis5', 'spis6', 'strk1', 'strk2', 'strk3', 'strk4', 'tt1', 'tt2', 'tt3', 'tt4', 'vos1']
|
||||
```
|
||||
Создадим строку со своей фамилией и инициалами преобразуем ее в список, затем список в кортеж, затем в строку
|
||||
|
||||
```py
|
||||
strk1 = "ЕфимоваЛА"
|
||||
spis = list(strk1)
|
||||
spis
|
||||
['Е', 'ф', 'и', 'м', 'о', 'в', 'а', 'Л', 'А']
|
||||
kort = tuple(spis)
|
||||
kort
|
||||
('Е', 'ф', 'и', 'м', 'о', 'в', 'а', 'Л', 'А')
|
||||
strk2 = str(kort)
|
||||
"('Е', 'ф', 'и', 'м', 'о', 'в', 'а', 'Л', 'А')"
|
||||
```
|
||||
## 4. Арифметические операции
|
||||
### 4.1. Сложение и вычитание
|
||||
|
||||
```py
|
||||
12+7+90 # Сложение целых чисел
|
||||
109
|
||||
5.689e-1 - 0.456 #Вычитание вещественных чисел
|
||||
0.11289999999999994
|
||||
23.6+54 #Сложение вещественного и целого чисел
|
||||
77.6
|
||||
14-56.7+89 # Сложение и вычитание целых и вещественных чисел
|
||||
46.3
|
||||
```
|
||||
### 4.2. Умножение
|
||||
```py
|
||||
-6.7*12 #Умножение вещественного числа на целое число
|
||||
-80.4
|
||||
```
|
||||
|
||||
### 4.3. Деление
|
||||
Результатом деления всегда будет вещественное число
|
||||
|
||||
```py
|
||||
-234.5/6 #Деление вещественного числа на целое
|
||||
-39.083333333333336
|
||||
a=178/45 #Деление двух целых чисел – проверьте тип объекта a!
|
||||
print(a, ' ', type(a))
|
||||
3.9555555555555557 <class 'float'>
|
||||
```
|
||||
|
||||
### 4.4. Деление c округлением вниз
|
||||
|
||||
```py
|
||||
b = 178 // 45 # 3.956 округляется вниз, т.е. до 3
|
||||
b
|
||||
3
|
||||
type(b)
|
||||
<class 'int'>
|
||||
c = -24.6 // 12.1 # -2.033 округляется вниз, т.е. до -3
|
||||
c
|
||||
-3.0
|
||||
type(c)
|
||||
<class 'float'>
|
||||
12 // 6.5
|
||||
1.0
|
||||
12.0 // 5
|
||||
2.0
|
||||
```
|
||||
### 4.5. Получение остатка от деления
|
||||
|
||||
```py
|
||||
148%33 #Остаток от деления двух целых чисел
|
||||
16
|
||||
12.6%3.8 #Остаток от деления двух вещественных чисел
|
||||
1.2000000000000002
|
||||
```
|
||||
### 4.6. Возведение в степень
|
||||
```py
|
||||
14**3 #Целое число возводится в целую степень
|
||||
2744
|
||||
e=2.7**3.6 #Вещественное число возводится в вещественную степень
|
||||
e
|
||||
35.719843790663525
|
||||
```
|
||||
С комплексными числами
|
||||
|
||||
```py
|
||||
z1 = 1 + 1j
|
||||
z2 = 2 + 2j
|
||||
z1+z2
|
||||
(3+3j)
|
||||
z1 - z2
|
||||
(-1-1j)
|
||||
z1 * z2
|
||||
4j
|
||||
z1 / z2
|
||||
(0.5+0j)
|
||||
z1 ** 2
|
||||
2j
|
||||
z1 // 2 # Операция целочисленного деления неприменима к комплексным числам
|
||||
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#12>", line 1, in <module>
|
||||
z1 // 2 # Операция целочисленного деления неприменима к комплексным числам
|
||||
TypeError: unsupported operand type(s) for //: 'complex' and 'int'
|
||||
|
||||
z1 % z2 # Операция получения остатка от деления также неприменима к комплексным числам
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#13>", line 1, in <module>
|
||||
z1 % z2 # Операция получения остатка от деления также неприменима к комплексным числам
|
||||
TypeError: unsupported operand type(s) for %: 'complex' and 'complex'
|
||||
```
|
||||
При проведении арифметических операций над числами разных типов, получается число, имеющее более сложный тип из использованных при его получении.
|
||||
|
||||
## 5. Операции с двоичными представлениями целых чисел
|
||||
### 5.1. Двоичная инверсия
|
||||
Двоичная инверсия (~). Значение каждого бита в представлении числа заменяется на
|
||||
противоположное значение (0 на 1, 1 на 0)
|
||||
```py
|
||||
dv1=9
|
||||
bin(dv1)
|
||||
'0b1001'
|
||||
dv2=~dv1
|
||||
bin(dv2)
|
||||
'-0b1010'
|
||||
```
|
||||
|
||||
### 5.2. Двоичное «И»
|
||||
Двоичное «И» - логическое умножение, побитовое совпадение двоичных представлений чисел.
|
||||
```py
|
||||
7&9 # 0111 и 1001 = 0001
|
||||
1
|
||||
bin(7)
|
||||
'0b111'
|
||||
bin(9)
|
||||
'0b1001'
|
||||
7&8 # 0111 и 1000 = 0000
|
||||
0
|
||||
bin(8)
|
||||
'0b1000'
|
||||
```
|
||||
### 5.3. Двоичное «ИЛИ»
|
||||
Двоичное «ИЛИ» - логическое сложение, побитовое совпадение двоичных представлений чисел, в котором 0 получается, только если оба сравниваемых разряда равны 0.
|
||||
```py
|
||||
7|9 # 0111 или 1001 = 1111
|
||||
15
|
||||
7|8 # 0111 или 1000 = 1111
|
||||
15
|
||||
14|5 # 1110 или 0101 = 1111
|
||||
15
|
||||
bin(15)
|
||||
'0b1111'
|
||||
```
|
||||
|
||||
### 5.4. Двоичное «исключаещее ИЛИ»
|
||||
Двоичное «исключающее ИЛИ» - побитовое совпадение двоичных представлений чисел, в котором 0 получается, только если оба сравниваемых разряда имеют одинаковые значения.
|
||||
```py
|
||||
14^5 # 1110 исключающее или 0101 = 1011
|
||||
11
|
||||
bin(11)
|
||||
'0b1011'
|
||||
```
|
||||
### 5.5. Поразрядный сдвиг
|
||||
Сдвиг двоичного представления на заданное число разрядов влево (<<) или вправо (>>) с
|
||||
дополнением нулями, соответственно справа или слева
|
||||
```py
|
||||
h=14 #Двоичное представление = 1110
|
||||
bin(h)
|
||||
'0b1110'
|
||||
g=h<<2 # Новое двоичное представление = 111000
|
||||
bin(g)
|
||||
'0b111000'
|
||||
g1=h>>1 # Новое двоичное представление = 0111
|
||||
bin(g1)
|
||||
'0b111'
|
||||
g2=h>>2 # Новое двоичное представление = 0011
|
||||
bin(g2)
|
||||
'0b11'
|
||||
```
|
||||
Операции с двоичными числами на практике
|
||||
|
||||
```py
|
||||
a = 251
|
||||
bin(a)
|
||||
'0b11111011'
|
||||
b = 293
|
||||
bin(b)
|
||||
'0b100100101'
|
||||
~a
|
||||
-252
|
||||
bin(~a)
|
||||
'-0b11111100'
|
||||
a&b # 011111011 и 100100101 = 000100001
|
||||
33
|
||||
bin(a&b)
|
||||
'0b100001'
|
||||
a|b # двоичное или - 011111011 и 100100101 = 111111111
|
||||
511
|
||||
bin(a|b)
|
||||
'0b111111111'
|
||||
a ^ b # Двоичное «исключающее ИЛИ» 0 если совпадают
|
||||
478
|
||||
bin(a^b)
|
||||
'0b111011110'
|
||||
bin(a>>3) # поразрядовый сдвиг вправо на 3
|
||||
'0b11111'
|
||||
```
|
||||
## 6. Операции при работе с последовательностями
|
||||
### 6.1. Объединение последовательностей
|
||||
|
||||
```py
|
||||
'Система '+'регулирования' #Соединение двух строк символов
|
||||
'Система регулирования'
|
||||
['abc','de','fg']+['hi','jkl'] # Объединение двух списков
|
||||
['abc', 'de', 'fg', 'hi', 'jkl']
|
||||
('abc','de','fg')+('hi','jkl') # Объединение двух кортежей
|
||||
('abc', 'de', 'fg', 'hi', 'jkl')
|
||||
```
|
||||
### 6.2. Повторение (*)
|
||||
|
||||
```py
|
||||
'ля-ля-ля-ля-ля-'
|
||||
['ку','-']*3 #Повторение списка 3 раза
|
||||
['ку', '-', 'ку', '-', 'ку', '-']
|
||||
('кис','-')*4 #Повторение кортежа 4 раза
|
||||
('кис', '-', 'кис', '-', 'кис', '-', 'кис', '-')
|
||||
signal1=[0]*3+[1]*99
|
||||
signal1
|
||||
[0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]
|
||||
signal2=(0,)*3+(1,)*5+(0,)*7signal2
|
||||
(0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0)
|
||||
```
|
||||
### 6.3. Проверка наличия заданного элемента в последовательности
|
||||
Наличие элемента в последовательность можно проверить с помощью оператора in.
|
||||
```py
|
||||
stroka='Система автоматического управления'
|
||||
'автомат' in stroka #Наличие подстроки в строке
|
||||
True
|
||||
'ку' in ['ку','-']*3 #Наличие контекста в списке
|
||||
True
|
||||
'ля-' in ('abc', 'de', 'fg', 'hi', 'jkl') #Наличие контекста в кортеже
|
||||
False
|
||||
```
|
||||
### 6.4. Подстановка значений в строку
|
||||
В строку символов можно подставлять заданные значения с помощью оператора %.
|
||||
```py
|
||||
stroka='Температура = %g %s %g'
|
||||
stroka
|
||||
'Температура = %g %s %g'
|
||||
stroka % (16,' меньше ',25)
|
||||
'Температура = 16 меньше 25'
|
||||
stroka='Температура = %(zn1)g %(sravn)s %(zn2)g' # вставка и сспользованием данных из словаря
|
||||
stroka % {'zn1':16,'sravn':' меньше ','zn2':25}
|
||||
'Температура = 16 меньше 25'
|
||||
```
|
||||
## 7. Оператор присваивания
|
||||
### 7.1. Обычное присваивание значения переменной
|
||||
```py
|
||||
zz=-12
|
||||
zz
|
||||
-12
|
||||
```
|
||||
### 7.2. Увеличение значения переменной на заданную величину или уменьшение
|
||||
Операторы += и -= позволяют увеличить или уменьшить значение переменной на заданную величину соответственно.
|
||||
```py
|
||||
zz+=5 # Значение zz увеличивается на 5
|
||||
zz
|
||||
-7
|
||||
zz-=3 # Значение уменьшается на 3
|
||||
zz
|
||||
-10
|
||||
stroka='Система'
|
||||
stroka+=' регулирования' stroka+=' регулирования'
|
||||
stroka
|
||||
'Система регулирования'
|
||||
```
|
||||
### 7.3. Умножение текущего значения переменной на заданную величину или деление
|
||||
Операторы /= и *= позволяют разделить или умножить значение переменной на заданную величину соответственно.
|
||||
```py
|
||||
zz/=2
|
||||
zz
|
||||
-5.0
|
||||
zz*=5
|
||||
zz
|
||||
-12.5
|
||||
str = 'ля'
|
||||
str*=3 # повторение заданной строки 3 раза
|
||||
str
|
||||
'ляляля'
|
||||
```
|
||||
### 7.4. Операции деления с округлением вниз получения остатка от деления и возведения в
|
||||
степень
|
||||
|
||||
```py
|
||||
a = 6
|
||||
a//=5 # целочисленное деление
|
||||
a
|
||||
1
|
||||
b = 13
|
||||
b%=6 # получение остатка от деления
|
||||
b
|
||||
1
|
||||
c = 2
|
||||
c **= 3 # возведение в степень
|
||||
c
|
||||
8
|
||||
```
|
||||
### 7.5. Множественное присваивание
|
||||
Присваивать определенные значения можно сразу нескольким переменным за раз.
|
||||
```py
|
||||
w=v=10 # Переменным присваивается одно и то же значение
|
||||
w,v
|
||||
(10, 10)
|
||||
n1,n2,n3=(11,-3,'all') #Значения переменных берутся из кортежа
|
||||
n1,n2,n3
|
||||
(11, -3, 'all')
|
||||
n1,n2,n3= [11, 12, 13] # можно из списка
|
||||
n1, n2, n3
|
||||
(11, 12, 13)
|
||||
n1,n2,n3= '12','rrr', 'iuuiui' # можно строки
|
||||
n1, n2, n3
|
||||
('12', 'rrr', 'iuuiui')
|
||||
n1,n2,n3= {1: 11, 2: 12, 3: 'eeee'} # можно словарь
|
||||
n1, n2, n3
|
||||
(1, 2, 3)
|
||||
n1,n2,n3= {11, 12, 'eeee'} # множество
|
||||
n1, n2, n3
|
||||
(11, 12, 'eeee')
|
||||
```
|
||||
## 8. Логические операции
|
||||
### 8.1. Операции сравнения
|
||||
```py
|
||||
w == v
|
||||
True
|
||||
w != v
|
||||
False
|
||||
w +=1
|
||||
w < v
|
||||
False
|
||||
w > v
|
||||
True
|
||||
w <= v
|
||||
False
|
||||
w>=v
|
||||
True
|
||||
```
|
||||
### 8.2. Проверка наличия заданного элемента в последовательности или во множестве, а также
|
||||
проверка наличия ключа в словаре
|
||||
Наличие элемента в сложном объекте также можно проверить с помощью оператора in
|
||||
|
||||
```py
|
||||
mnoz1={'pen','book','pen','iPhone','table','book'} # с множеством
|
||||
'book' in mnoz1True
|
||||
'cap' in mnoz1
|
||||
False
|
||||
|
||||
dic1={'Saratov':145, 'Orel':56, 'Vologda':45} # со словарем
|
||||
'Vologda' in dic1
|
||||
True
|
||||
'Pskov' in dic1
|
||||
False
|
||||
56 in dic1.values() # проверка наличия значения в словаре
|
||||
True
|
||||
|
||||
dct1={'Institut':['AVTI','IEE','IBB'],'Depart':['UII','PM','VMSS','MM'],'gruppa': ['A01-15','A-02-15']}
|
||||
'UII' in dct1['Depart']
|
||||
True
|
||||
dct1['Depart'][1] == 'MM' # сравнение значения словаря по ключу
|
||||
False
|
||||
```
|
||||
### 8.3. Создание больших логических выражений
|
||||
С помощью соединительных слов and, or и not можно создавать большие логические выражения.
|
||||
```py
|
||||
a=17
|
||||
b=-6
|
||||
(a>=b) and ('book' in mnoz1) and not ('Pskov' in dic1)
|
||||
True
|
||||
(a%2==1) and ("pen" in mnoz1) or (120 in dic1.values())
|
||||
True
|
||||
not (b < 0) or (len(mnoz1)== 4)
|
||||
True
|
||||
```
|
||||
### 8.4. Проверка ссылок переменных на один и тот же объект
|
||||
Сравнивать ссылки на объект можно с помощью оператора is.
|
||||
|
||||
```py
|
||||
w=v=10 #При таком присваивании переменные ссылаются на один и тот же объект в оперативной памяти
|
||||
w is v
|
||||
True
|
||||
w1=['A','B']
|
||||
v1=['A','B']
|
||||
w1 is v1
|
||||
False
|
||||
```
|
||||
В последнем случае значение False так как переменные создавались отдельно, хоть их значения и совпадают.
|
||||
Они хранятся в разных ячейках памяти и их ссылки разные.
|
||||
|
||||
## 9. Операции с объектами, выполняемые с помощью методов
|
||||
### 9.1 Методы для работы со строками
|
||||
|
||||
```py
|
||||
stroka='Микропроцессорная система управления'
|
||||
dir(stroka)['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'removeprefix', 'removesuffix', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
|
||||
stroka.find('пр') #Возвращает номер позиции первого вхождения указанного контекста или значение -1
|
||||
5
|
||||
stroka='Микропроцессорная система управления'
|
||||
stroka.find('пр') #Возвращает номер позиции первого вхождения указанного контекста или значение -1
|
||||
5
|
||||
stroka.count("с") #Подсчет числа вхождений строки “с” в stroka
|
||||
4
|
||||
stroka.replace(' у',' автоматического у')
|
||||
'Микропроцессорная система автоматического управления'
|
||||
spis22=stroka.split(' ') #Возвращает список подстрок, между которыми в строке стоит заданный разделитель
|
||||
spis22
|
||||
['Микропроцессорная', 'система', 'управления']
|
||||
stroka.upper() #Возвращает строку со всеми заглавными буквами
|
||||
'МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ'
|
||||
stroka3=" ".join(spis22) #Возвращает строку, собранную из элементов списка
|
||||
stroka3
|
||||
'Микропроцессорная система управления'
|
||||
stroka3.partition("с") #Возвращает кортеж с результатами поиска «с» слева('Микропроце', 'с', 'сорная система управления')
|
||||
stroka3.rpartition("с") #Возвращает кортеж с результатами поиска «с» справа
|
||||
('Микропроцессорная си', 'с', 'тема управления')
|
||||
```
|
||||
Метод format() используется для форматирования строк по следующему принципу:
|
||||
1. Если в форматированной строке не указан порядок вставки элементов, то они войдут в неё в порядке их передачи в метод,
|
||||
2. Если в форматированной строке указан порядок вставки элементов, то они войдут в неё в с таким же порядком,
|
||||
3. Если в форматированной строке поименно указаны позиции вставки элементов, то они войдут в неё в соответствии с ними.
|
||||
```py
|
||||
strk1='Момент времени {}, значение = {}'
|
||||
strk1.format(1,89.7)
|
||||
'Момент времени 1, значение = 89.7'
|
||||
strk2='Момент времени {1}, значение = {0}:{2}' # в фигурных скобках индексы, определяеют порядок аргументов формата
|
||||
strk2.format(36.7,2,'норма!')
|
||||
'Момент времени 2, значение = 36.7:норма!'
|
||||
strk3='Момент времени {num}, значение = {znch}' # в фигурных скобках имена аргументов
|
||||
strk3.format(znch=89.7,num=2)
|
||||
'Момент времени 2, значение = 89.7'
|
||||
```
|
||||
### 9.2. Методы для работы со списками
|
||||
|
||||
```py
|
||||
spsk = [1, 2, 3, 4, 5, 6]
|
||||
spsk.pop(2) # удаление элемента по индексу, с возвращением его значения
|
||||
3
|
||||
spsk
|
||||
[1, 2, 4, 5, 6]
|
||||
spsk.append('c') # добавление элемента в конец списка
|
||||
spsk
|
||||
[1, 2, 4, 5, 6, 'c']
|
||||
spsk.insert(2,'a') # добавление элемента на указанную позицию
|
||||
spsk
|
||||
[1, 2, 'a', 4, 5, 6, 'c']
|
||||
spsk.count('a') # подсчет количества соответсвующих элементо
|
||||
1
|
||||
```
|
||||
### 9.3. Методы для работы с кортежами
|
||||
|
||||
```py
|
||||
kortezh = (1, 2, 3, 4, 5, 6, 7)
|
||||
kortezh.count(3) # количество соответсвующих элементов в кортеже
|
||||
1
|
||||
kortezh.index(2) # вычисление индекса переданного элемента если он есть в кортеже
|
||||
1
|
||||
```
|
||||
### 9.4. Методы для словарей и множеств
|
||||
|
||||
```py
|
||||
dictionary = {"A" : 1, "B" : 2, "C" : 3, "D" : 4, "E" : 5}
|
||||
dictionary.get("D") # Получение значения из словаря по соответствующему ему ключу
|
||||
|
||||
dictionary.items() # Получение списка кортежей всех пар ключ-значений в словаре
|
||||
dict_items([('A', 1), ('B', 2), ('C', 3), ('D', 4), ('E', 5)])
|
||||
|
||||
dictionary.keys() # Получение списка всех ключей в словаре
|
||||
dict_keys(['A', 'B', 'C', 'D', 'E'])
|
||||
|
||||
dictionary.values() # Получение списка всех значений в словаре
|
||||
dict_values([1, 2, 3, 4, 5])
|
||||
|
||||
dictionary.pop("C") # Удаление определенной пары ключ-значение из словаря по переданному ключу
|
||||
3
|
||||
dictionary
|
||||
{'A': 1, 'B': 2, 'D': 4, 'E': 5}
|
||||
|
||||
dictionary.popitem() # Удаление последней пары ключ-значение из словаря
|
||||
('E', 5)
|
||||
dictionary
|
||||
{'A': 1, 'B': 2, 'D': 4}
|
||||
|
||||
dictionary.update({"A" : 5}) # Обновление словаря новыми значениями
|
||||
dictionary
|
||||
{'A': 5, 'B': 2, 'D': 4}
|
||||
|
||||
dictionary.clear() # Очистка словаря
|
||||
dictionary
|
||||
{}
|
||||
```
|
||||
Методы для работы с множествами отчасти схожи с методами словарей, однако среди них также есть и уникальные методы.
|
||||
|
||||
```py
|
||||
mnozhestvo = {"Apple", "Orange", "Peach", "Pear"}
|
||||
mnozhestvo.add("Banana") # Добавление элемента в множество
|
||||
mnozhestvo
|
||||
{'Banana', 'Pear', 'Peach', 'Apple', 'Orange'}
|
||||
mnozhestvo2 = mnozhestvo.copy() # Копирование множества
|
||||
mnozhestvo2
|
||||
{'Peach', 'Banana', 'Apple', 'Orange', 'Pear'}
|
||||
mnozhestvo2.remove("Apple") # Удаление элемента из множества
|
||||
mnozhestvo2
|
||||
{'Peach', 'Banana', 'Orange', 'Pear'}
|
||||
mnozhestvo.difference(mnozhestvo2) # Сравнение двух множеств по содержимому, возвращает разницу
|
||||
{'Apple'}
|
||||
mnozhestvo2.clear() # Очистка множества
|
||||
mnozhestvo2
|
||||
set()
|
||||
```
|
||||
|
||||
## 10. Завершение работы со средой.
|
||||
@ -0,0 +1,52 @@
|
||||
# Индивидуальное контрольное задание модуль 1
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## Задание вариант 9
|
||||
|
||||
1.В каком месте инструкции и как можно написать комментарий?
|
||||
|
||||
После любой инструкции или на отдельной строке после знака #
|
||||
|
||||
2.Создайте объект-список с 10 элементами - русскоязычными названиями продуктов. Напишите инструкцию, доказывающую, что создан объект именно требуемого типа.
|
||||
Напишите инструкцию отображения списка атрибутов созданного объекта.
|
||||
|
||||
```py
|
||||
spis = ["Помидор", "Огурец", "Сухарики","Сыр","Шоколадка","Молоко","Пицца","Чипсы","Яйца","Кофе"]
|
||||
type(spis)
|
||||
<class 'list'>
|
||||
dir(spis)
|
||||
['__add__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getstate__', '__gt__', '__hash__', '__iadd__', '__imul__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']
|
||||
```
|
||||
|
||||
3. Удалите из списка 5 и 6 элементы, считая от первого. Определите число оставшихся элементов. Замените 4-й элемент на "трюфель". Отобразите получившийся объект.
|
||||
|
||||
```py
|
||||
spis.remove(spis[5])
|
||||
spis.remove(spis[4])
|
||||
spis
|
||||
['Помидор', 'Огурец', 'Сухарики', 'Сыр', 'Пицца', 'Чипсы', 'Яйца', 'Кофе']
|
||||
spis[3]="трюфель"
|
||||
spis
|
||||
['Помидор', 'Огурец', 'Сухарики', 'трюфель', 'Пицца', 'Чипсы', 'Яйца', 'Кофе']
|
||||
```
|
||||
|
||||
4. Преобразуйте список в кортеж. Отобразите полученный объект. Создайте новый кортеж с удалением из ранее созданного кортежа элемента "трюфель".
|
||||
|
||||
```py
|
||||
kort=tuple(spis)
|
||||
kort
|
||||
('Помидор', 'Огурец', 'Сухарики', 'трюфель', 'Пицца', 'Чипсы', 'Яйца', 'Кофе')
|
||||
kort_1=kort[0:3] + kort[4:] # кортеж неизменяем, создаем новый
|
||||
kort_1
|
||||
('Помидор', 'Огурец', 'Сухарики', 'Пицца', 'Чипсы', 'Яйца', 'Кофе')
|
||||
```
|
||||
|
||||
5.Напишите инструкцию проверки наличия в списке элемента "молоко". Если его нет в списке, добавьте его туда, иначе - удалите его из списка.
|
||||
|
||||
```py
|
||||
"Молоко" in spis
|
||||
False
|
||||
spis.append("Молоко")
|
||||
spis
|
||||
['Помидор', 'Огурец', 'Сухарики', 'трюфель', 'Пицца', 'Чипсы', 'Яйца', 'Кофе', 'Молоко']
|
||||
```
|
||||
@ -0,0 +1,79 @@
|
||||
# Общее контрольно задание по теме 3
|
||||
Ефисова Людмила, А-03-23
|
||||
|
||||
## Задание
|
||||
Реализовать, записать в текстовый файл и проанализировать результаты последовательности
|
||||
инструкций, выполняющих следующие действия:
|
||||
1. Преобразовать восьмеричное значение 45 в целое число.
|
||||
|
||||
2. Создать объект-словарь D со значениями {"усиление":23, "запаздывание":12, "постоянная
|
||||
времени":78} и затем осуществить его преобразование в два списка: ключей и значений, а
|
||||
затем – эти два списка преобразовать в один кортеж. Чем отличается кортеж от списка?
|
||||
|
||||
3. Напишите и выполните единое выражение, осуществляющее деление числа 1768 на 24.8 с
|
||||
округлением вниз, с определением после этого остатка от деления получившегося значения на
|
||||
3 и затем возведения результата в степень 2.4.
|
||||
|
||||
4. Напишите и выполните единое выражение, последовательно осуществляющее следующие
|
||||
операции: двоичное И для чисел 13 и 27, инверсия полученного значения, двоичное
|
||||
исключающее ИЛИ для полученного значения и числа 14, сдвиг полученного значения на два
|
||||
разряда влево.
|
||||
|
||||
5. Создать список с 4 одинаковыми элементами 'колебат' и написать оператор проверки наличия
|
||||
комбинации символов 'аткол' в результате конкатенации второго и третьего элементов этого
|
||||
списка.
|
||||
|
||||
6. Определить список методов, доступных у ранее созданного словаря D. Поочередно
|
||||
использовать его методы keys и values, определить, что можно получить с применением этих
|
||||
методов.
|
||||
|
||||
7. Создать объект - символьную строку с текстом данного предложения. Из символьной строки
|
||||
создать список, элементами которого будут отдельные слова из созданной строки. Заменить в
|
||||
списке элемент «-» на «,». Удалить из списка элемент со значением «данного». Отобразить
|
||||
получившийся список.
|
||||
|
||||
```py
|
||||
a = int("45", 8) #1 пункт
|
||||
a
|
||||
37
|
||||
|
||||
D = {"усиление":23, "запаздывание":12, "постояннаявремени":78} #2 пункт
|
||||
D_key = list(D.keys())
|
||||
D_values = list(D.values())
|
||||
D_key, D_values
|
||||
(['усиление', 'запаздывание', 'постояннаявремени'], [23, 12, 78])
|
||||
D_tuple = tuple(zip(D_key, D_values)) # создали кортеж, он неизменяемый в отличие от списка
|
||||
D_tuple
|
||||
(('усиление', 23), ('запаздывание', 12), ('постояннаявремени', 78))
|
||||
|
||||
((1768//24.8)%3) ** 2.4 # 3 пункт
|
||||
5.278031643091577
|
||||
|
||||
(~ (13 & 27) ^ 14) << 2 # 4 пункт
|
||||
-32
|
||||
|
||||
spis = ["колебат"] * 4 # 5 пункт
|
||||
spis
|
||||
['колебат', 'колебат', 'колебат', 'колебат']
|
||||
"аткол" in spis[1] + spis[2]
|
||||
True
|
||||
|
||||
dir(D) # 6 пункт
|
||||
['__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__ior__', '__iter__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__ror__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'clear', 'copy', 'fromkeys', 'get', 'items', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values']
|
||||
|
||||
D.keys()
|
||||
dict_keys(['усиление', 'запаздывание', 'постояннаявремени'])
|
||||
D.value()
|
||||
dict_values([23, 12, 78])
|
||||
|
||||
string = "Создать объект - символьную строку с текстом данного предложения." # 7 пункт
|
||||
string_list = string.split(" ")
|
||||
string_list
|
||||
['Создать', 'объект', '-', 'символьную', 'строку', 'с', 'текстом', 'данного', 'предложения.']
|
||||
string_list[string_list.index("-")] = ","
|
||||
string_list
|
||||
['Создать', 'объект', ',', 'символьную', 'строку', 'с', 'текстом', 'данного', 'предложения.']
|
||||
string_list.remove('данного')
|
||||
string_list
|
||||
['Создать', 'объект', ',', 'символьную', 'строку', 'с', 'текстом', 'предложения.']
|
||||
```
|
||||
|
После Ширина: | Высота: | Размер: 42 KiB |
|
После Ширина: | Высота: | Размер: 56 KiB |
|
После Ширина: | Высота: | Размер: 34 KiB |
|
После Ширина: | Высота: | Размер: 14 KiB |
|
После Ширина: | Высота: | Размер: 38 KiB |
@ -0,0 +1,304 @@
|
||||
# Отчет по теме 4
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## 1. Запустила оболочку IDLE создала рабочий протокол
|
||||
## 2. Стандартные функции.
|
||||
|
||||
### 2.1. Функция округления числа с заданной точностью round().
|
||||
|
||||
```py
|
||||
help(round)
|
||||
Help on built-in function round in module builtins:
|
||||
|
||||
round(number, ndigits=None)
|
||||
Round a number to a given precision in decimal digits.
|
||||
|
||||
The return value is an integer if ndigits is omitted or None. Otherwise
|
||||
the return value has the same type as the number. ndigits may be negative.
|
||||
|
||||
round(123.456,1)
|
||||
123.5
|
||||
round(123.456,0)
|
||||
123.0
|
||||
type(round(123.456,1)
|
||||
<class 'float'>
|
||||
type(round(123.456,0))
|
||||
<class 'float'>
|
||||
round(123.456)
|
||||
123
|
||||
type(round(123.456))
|
||||
<class 'int'>
|
||||
```
|
||||
### 2.2. Функция создания последовательности целых чисел с заданным шагом range().
|
||||
|
||||
```py
|
||||
gg=range(76,123,9)
|
||||
gg
|
||||
range(76, 123, 9)
|
||||
list(gg)
|
||||
[76, 85, 94, 103, 112, 121]
|
||||
range(23)
|
||||
range(0, 23) # создает последовательность целых чисел от 0 до 22 с шагом 1
|
||||
list(range(23))
|
||||
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22]
|
||||
type(gg)
|
||||
<class 'range'>
|
||||
```
|
||||
### 2.3. Функция создания общего объекта, элементами которого являются кортежи zip().
|
||||
|
||||
```py
|
||||
qq = ["Ефимова", "Девятова", "Беженарь", "Антонов"]
|
||||
ff=zip(gg,qq)
|
||||
ff # итерируемый объект просто так нельзя увидеть
|
||||
<zip object at 0x000001F7810C4340>
|
||||
tuple(ff)
|
||||
((76, 'Ефимова'), (85, 'Девятова'), (94, 'Беженарь'), (103, 'Антонов'))
|
||||
ff[1] # нельзя обращаться с помощью индекса
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#12>", line 1, in <module>
|
||||
ff[1]
|
||||
TypeError: 'zip' object is not subscriptable
|
||||
```
|
||||
Длина результирующего объекта равна длине самого короткого объекта из переданных функции.
|
||||
|
||||
### 2.4. Функция вычисляющая значения выражения, корректно записанного на языке Python и представленного в виде символьной строки eval()
|
||||
|
||||
```py
|
||||
fff=float(input('коэффициент усиления=')); dan=eval('5*fff-156')
|
||||
коэффициент усиления=3
|
||||
dan
|
||||
-141.0
|
||||
```
|
||||
### 2.5. Похожая на eval() функция exec().
|
||||
Xтение и выполнение объекта-аргумента функции.
|
||||
Этот объект должен представлять собой строку символов с совокупностью инструкций на языке Python.
|
||||
|
||||
```py
|
||||
exec(input('введите инструкции:'))
|
||||
введите инструкции:perem=-123.456;gg=round(abs(perem)+98,3)
|
||||
gg
|
||||
221.456
|
||||
```
|
||||
### 2.6. Функции abs, pow, max, min, sum, divmod, len, map.
|
||||
|
||||
```py
|
||||
abs(-100) # Получение модуля числа
|
||||
100
|
||||
pow(2, 5) # Возведение чисда в степень
|
||||
32
|
||||
max(1, 2, 3, 10) # Получение максимального числа из переданной последовательности
|
||||
10
|
||||
min(1, 2, 3, 10) # Получение минимального числа из переданной последовательности
|
||||
1
|
||||
sum([1, 2, 3, 10]) # Суммирование элементов переданной последовательности
|
||||
16
|
||||
divmod(11, 4) # Получение кортежа с двумя элементами: результатами целочисленного деления и деления с остатком
|
||||
(2, 3)
|
||||
len([1, 2, 3, 10])
|
||||
4
|
||||
|
||||
def cube(x):
|
||||
return x ** 2
|
||||
map(cube, [1, 2, 3, 10]) # Применение заданной функции ко всем элементам переданной последовательности
|
||||
<map object at 0x000001F783989F60>
|
||||
list(map(cube, [1, 2, 3, 10]))
|
||||
[1, 4, 9, 100]
|
||||
```
|
||||
## 3. Функции из стандартного модуля math
|
||||
|
||||
```py
|
||||
import math
|
||||
dir(math)
|
||||
['__doc__', '__loader__', '__name__', '__package__', '__spec__', 'acos', 'acosh', 'asin', 'asinh', 'atan', 'atan2', 'atanh', 'cbrt', 'ceil', 'comb', 'copysign', 'cos', 'cosh', 'degrees', 'dist', 'e', 'erf', 'erfc', 'exp', 'exp2', 'expm1', 'fabs', 'factorial', 'floor', 'fma', 'fmod', 'frexp', 'fsum', 'gamma', 'gcd', 'hypot', 'inf', 'isclose', 'isfinite', 'isinf', 'isnan', 'isqrt', 'lcm', 'ldexp', 'lgamma', 'log', 'log10', 'log1p', 'log2', 'modf', 'nan', 'nextafter', 'perm', 'pi', 'pow', 'prod', 'radians', 'remainder', 'sin', 'sinh', 'sqrt', 'sumprod', 'tan', 'tanh', 'tau', 'trunc', 'ulp']
|
||||
|
||||
help(math.factorial)
|
||||
Help on built-in function factorial in module math:
|
||||
|
||||
factorial(n, /)
|
||||
Find n!.
|
||||
math.factorial(5) # Факториал числа
|
||||
120
|
||||
math.sin(math.pi / 6) # Расчет синуса числа
|
||||
0.49999999999999994
|
||||
math.acos(0.5) * 180 / math.pi # Расчет арккосинуса числа
|
||||
60.00000000000001
|
||||
math.degrees(math.pi / 6) # Перевод угла в радианах в градусы
|
||||
29.999999999999996
|
||||
math.radians(60) # Перевод угла в градусах в радианы
|
||||
1.0471975511965976
|
||||
math.exp(2) # Возведение числа Эйлера в определенную степень
|
||||
7.38905609893065
|
||||
math.log(8, 2) # Вычисление логарифма с определенным основанием
|
||||
3.0
|
||||
math.log10(100) # Вычисление десятичного логарифма
|
||||
2.0
|
||||
math.sqrt(64) # Вычисление квадратного корня
|
||||
8.0
|
||||
math.ceil(4.25) # Округление в большую сторону
|
||||
5
|
||||
math.floor(4.25) # Округление в меньшую сторону
|
||||
4
|
||||
|
||||
math.sin(2 * math.pi / 7 + math.exp(0.23))
|
||||
0.8334902641414562
|
||||
```
|
||||
## 4. Изучение функций из модуля cmath.
|
||||
|
||||
```py
|
||||
import cmath
|
||||
dir(cmath)['__doc__', '__loader__', '__name__', '__package__', '__spec__', 'acos', 'acosh', 'asin', 'asinh', 'atan', 'atanh', 'cos', 'cosh', 'e', 'exp', 'inf', 'infj', 'isclose', 'isfinite', 'isinf', 'isnan', 'log', 'log10', 'nan', 'nanj', 'phase', 'pi', 'polar', 'rect', 'sin', 'sinh', 'sqrt', 'tan', 'tanh', 'tau']
|
||||
cmath.sqrt(1.2-0.5j) # Вычисление квадратного корня из комплексного числа
|
||||
(1.118033988749895-0.22360679774997896j)
|
||||
cmath.phase(1-0.5j) # Вычисление фазы комплексного числа
|
||||
-0.4636476090008061
|
||||
```
|
||||
|
||||
## 5. Изучение стандартного модуля random.
|
||||
|
||||
```py
|
||||
import random
|
||||
dir(random)
|
||||
['BPF', 'LOG4', 'NV_MAGICCONST', 'RECIP_BPF', 'Random', 'SG_MAGICCONST', 'SystemRandom', 'TWOPI', '_ONE', '_Sequence', '__all__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', '_accumulate', '_acos', '_bisect', '_ceil', '_cos', '_e', '_exp', '_fabs', '_floor', '_index', '_inst', '_isfinite', '_lgamma', '_log', '_log2', '_os', '_parse_args', '_pi', '_random', '_repeat', '_sha512', '_sin', '_sqrt', '_test', '_test_generator', '_urandom', 'betavariate', 'binomialvariate', 'choice', 'choices', 'expovariate', 'gammavariate', 'gauss', 'getrandbits', 'getstate', 'lognormvariate', 'main', 'normalvariate', 'paretovariate', 'randbytes', 'randint', 'random', 'randrange', 'sample', 'seed', 'setstate', 'shuffle', 'triangular', 'uniform', 'vonmisesvariate', 'weibullvariate']
|
||||
help(random.seed)
|
||||
Help on method seed in module random:
|
||||
|
||||
seed(a=None, version=2) method of random.Random instance
|
||||
Initialize internal state from a seed.
|
||||
|
||||
The only supported seed types are None, int, float,
|
||||
str, bytes, and bytearray.
|
||||
|
||||
None or no argument seeds from current time or from an operating
|
||||
system specific randomness source if available.
|
||||
|
||||
If *a* is an int, all bits are used.
|
||||
|
||||
For version 2 (the default), all of the bits are used if *a* is a str,
|
||||
bytes, or bytearray. For version 1 (provided for reproducing random
|
||||
sequences from older versions of Python), the algorithm for str and
|
||||
bytes generates a narrower range of seeds.
|
||||
|
||||
random.seed() #задает случайное начальное состояние для псевдослучайных чисел
|
||||
random.random() # Равномерно распределенное случайное число
|
||||
0.3956737606722922
|
||||
random.uniform(1, 2) # Равномерно распределенное случайное число
|
||||
1.2506275428676115
|
||||
random.randint(5, 6) # Случайное целое число
|
||||
5
|
||||
random.gauss(5, 0.2) # Нормально распределенное случайное число
|
||||
4.575306564580744
|
||||
random.choice(["Apple", "Orange", "Pear"]) # Случайный выбор элемента из совокупности
|
||||
'Orange'
|
||||
fruits = ["Apple", "Orange", "Pear"]
|
||||
random.shuffle(fruits) # Перемешивание элементов списка
|
||||
fruits
|
||||
['Orange', 'Apple', 'Pear']
|
||||
random.sample(fruits, 2) # Получение выборки заданной размерности из совокупности
|
||||
['Apple', 'Orange']
|
||||
random.betavariate(1, 2) # Случайное число с бета-распределением
|
||||
0.19723446300643666
|
||||
random.gammavariate(1, 2) # Случайное число с гамма-распределением
|
||||
0.004344283624993138
|
||||
```
|
||||
Cписок с 4 случайными значениями подчиняющимися равномерному, нормальному, бета и гамма – распределениям.
|
||||
|
||||
```py
|
||||
[random.uniform(1, 5), random.gauss(2, 1), random.betavariate(1, 2), random.gammavariate(1, 2)]
|
||||
[1.937226676440678, 1.2213894819097244, 0.9228424699324803, 0.8536430488572739]
|
||||
```
|
||||
## 6. Изучение функций из модуля time.
|
||||
|
||||
```py
|
||||
import time
|
||||
dir(time)
|
||||
['_STRUCT_TM_ITEMS', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'altzone', 'asctime', 'ctime', 'daylight', 'get_clock_info', 'gmtime', 'localtime', 'mktime', 'monotonic', 'monotonic_ns', 'perf_counter', 'perf_counter_ns', 'process_time', 'process_time_ns', 'sleep', 'strftime', 'strptime', 'struct_time', 'thread_time', 'thread_time_ns', 'time', 'time_ns', 'timezone', 'tzname']
|
||||
c1=time.time() # Время в секундах, прошедшее с начала эпохи 1.1.1970
|
||||
c1
|
||||
1761258327.4259675
|
||||
c2=time.time()-c1 # Получение времени со ввода предыдущей команды
|
||||
c2
|
||||
19.33849573135376
|
||||
dat=time.gmtime() # Получение полной информации о текущем времени
|
||||
dat
|
||||
time.struct_time(tm_year=2025, tm_mon=10, tm_mday=23, tm_hour=22, tm_min=26, tm_sec=24, tm_wday=3, tm_yday=296, tm_isdst=0)
|
||||
dat.tm_mon # Получение текущего месяца
|
||||
10
|
||||
dat.tm_hour # Получение текущего часа
|
||||
22
|
||||
datLocal = time.localtime() # Получение полной информации о текущем "местном" времени
|
||||
datLocal
|
||||
time.struct_time(tm_year=2025, tm_mon=10, tm_mday=24, tm_hour=1, tm_min=28, tm_sec=16, tm_wday=4, tm_yday=297, tm_isdst=0)
|
||||
time.asctime(datLocal) # Преобразование представления времени из кортежа в строку
|
||||
'Fri Oct 23 01:28:16 2025'
|
||||
time.ctime(c1) # Преобразование времени в секундах, прошедшего с начала эпохи, в строку
|
||||
'Fri Oct 23 01:25:27 2025'
|
||||
time.sleep(10) # Прерывание работы программы на заданное количество секунд
|
||||
time.mktime(datLocal) # Преобразование времени из кортежа или структуры в число секунд с начала эпохи
|
||||
1761258496.0
|
||||
```
|
||||
## 7. Графические функции.
|
||||
|
||||
```py
|
||||
import pylab
|
||||
x=list(range(-3,55,4))
|
||||
t=list(range(15))
|
||||
pylab.plot(t,x) #Создание графика в оперативной памяти
|
||||
pylab.title('Первый график')
|
||||
pylab.xlabel('время')
|
||||
pylab.ylabel('сигнал')
|
||||
pylab.show() #Отображение графика на экране
|
||||
```
|
||||

|
||||
|
||||
На одном рисунке можно изображать несколько графиков
|
||||
|
||||
```py
|
||||
X1=[12,6,8,10,7]
|
||||
X2=[5,7,9,11,13]
|
||||
pylab.plot(X1)
|
||||
pylab.plot(X2)
|
||||
pylab.show()
|
||||
```
|
||||
|
||||

|
||||
|
||||
Построение круговой диаграммы
|
||||
|
||||
```py
|
||||
region=['Центр','Урал','Сибирь','Юг'] #Метки для диаграммы
|
||||
naselen=[65,12,23,17] # Значения для диаграммы
|
||||
pylab.pie(naselen,labels=region) #Создание диаграммы в памяти
|
||||
pylab.show() #Отображение диаграммы
|
||||
```
|
||||

|
||||
|
||||
Построение гистограммы
|
||||
```py
|
||||
pylab.hist([1, 2, 3, 1, 1, 2, 2, 2, 2, 4, 4], bins = 4)
|
||||
pylab.show()
|
||||
```
|
||||

|
||||
|
||||
```py
|
||||
pylab.bar(region, naselen)
|
||||
pylab.show()
|
||||
```
|
||||

|
||||
|
||||
## 8. Статистические функции из модуля statistics.
|
||||
|
||||
```py
|
||||
import statistics
|
||||
dir(statistics)
|
||||
['Counter', 'Decimal', 'Fraction', 'LinearRegression', 'NormalDist', 'StatisticsError', '_SQRT2', '__all__', '__annotations__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', '_coerce', '_convert', '_decimal_sqrt_of_frac', '_exact_ratio', '_fail_neg', '_float_sqrt_of_frac', '_integer_sqrt_of_frac_rto', '_isfinite', '_kernel_invcdfs', '_mean_stdev', '_newton_raphson', '_normal_dist_inv_cdf', '_quartic_invcdf', '_quartic_invcdf_estimate', '_random', '_rank', '_sqrt_bit_width', '_sqrtprod', '_ss', '_sum', '_triweight_invcdf', '_triweight_invcdf_estimate', 'acos', 'asin', 'atan', 'bisect_left', 'bisect_right', 'correlation', 'cos', 'cosh', 'count', 'covariance', 'defaultdict', 'erf', 'exp', 'fabs', 'fmean', 'fsum', 'geometric_mean', 'groupby', 'harmonic_mean', 'hypot', 'isfinite', 'isinf', 'itemgetter', 'kde', 'kde_random', 'linear_regression', 'log', 'math', 'mean', 'median', 'median_grouped', 'median_high', 'median_low', 'mode', 'multimode', 'namedtuple', 'numbers', 'pi', 'pstdev', 'pvariance', 'quantiles', 'random', 'reduce', 'repeat', 'sin', 'sqrt', 'stdev', 'sumprod', 'sys', 'tan', 'tau', 'variance']
|
||||
statistics.mean([1, 2, 3, 4, 5, 6, 7, 8, 9]) # Вычисление среднего
|
||||
5
|
||||
statistics.stdev([1, 2, 3, 4, 5, 6, 7, 8, 9]) # Вычисление среднеквадратичного отклонения
|
||||
2.7386127875258306
|
||||
statistics.median([1, 2, 3, 4, 5, 6, 7, 8]) # Вычисление медианы
|
||||
4.5
|
||||
```
|
||||
|
||||
## 9. Завершила работу со средой
|
||||
|
||||
|
||||
@ -0,0 +1,61 @@
|
||||
# Общее контрольное задание по теме 4
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## Задание
|
||||
Реализовать, записать в текстовый файл и проанализировать результаты последовательности
|
||||
инструкций, выполняющих следующие действия:
|
||||
|
||||
1. Напишите и исполните единое выражение, реализующее последовательное выполнение
|
||||
следующих операций: вычисление фазы комплексного числа 0.2+0.8j, округление результата
|
||||
до двух знаков после запятой, умножение полученного значения на 20, получение кортежа из
|
||||
двух значений: округленное вниз значение от деления результата на 3 и остатка от этого
|
||||
деления.
|
||||
|
||||
2. Создайте объект класса struct_time с временными параметрами для текущего московского
|
||||
времени. Создайте строку с текущим часом и минутами.
|
||||
|
||||
3. Создайте список с элементами – названиями дней недели. Сделайте случайную выборку из
|
||||
этого списка с тремя днями недели.
|
||||
|
||||
4. Напишите инструкцию случайного выбора числа из последовательности целых чисел от 14 до
|
||||
32 с шагом 3.
|
||||
|
||||
5. Сгенерируйте нормально распределенное число N с математическим ожиданием 15 и
|
||||
стандартным отклонением 4 и округлите его до целого значения. Создайте список с N
|
||||
элементами – случайно выбранными буквами латинского алфавита.
|
||||
|
||||
6. Напишите инструкцию для определения временного интервала в минутах, прошедшего с
|
||||
момента предыдущего (из п.2) определения временных параметров.
|
||||
|
||||
```py
|
||||
import cmath # пункт 1
|
||||
divmod(round(cmath.phase(0.2+0.8j),2)*20,3)
|
||||
(8.0, 2.6000000000000014)
|
||||
|
||||
import time # пункт 2
|
||||
Time=time.time()
|
||||
MosSec= Time + 3*60*60
|
||||
MosTime=time.gmtime(MosSec)
|
||||
print("Current time: {}:{}".format(MosTime.tm_hour, MosTime.tm_min))
|
||||
Current time: 23:1
|
||||
|
||||
import random # пункт 3
|
||||
Days = ["Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday"]
|
||||
random.sample(Days, 3)
|
||||
['Wednesday', 'Tuesday', 'Monday']
|
||||
|
||||
random.choice(range(14, 33, 3)) # пункт 4
|
||||
32
|
||||
|
||||
N = math.floor(random.gauss(15, 4)) # пункт 5
|
||||
N
|
||||
19
|
||||
import string # модуль с латинским алфавитом
|
||||
letters = random.sample(string.ascii_letters, N)
|
||||
letters
|
||||
['p', 'A', 'h', 'X', 'F', 'a', 'C', 'M', 'b', 'L', 'e', 'P', 'G', 'k', 'u', 'o', 'K', 'E', 'B']
|
||||
|
||||
timeDiff = round(time.time() - time.mktime(localTime)) # пункт 6
|
||||
print(timeDiff // 60, "minutes and", timeDiff % 60, "seconds")
|
||||
40 minutes and 36 seconds
|
||||
```
|
||||
@ -0,0 +1,40 @@
|
||||
# Индивидуальное контрольное задание по теме 4
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## Задание вариант 23
|
||||
|
||||
Напишите инструкцию запоминания в переменной Московского регионального времени.
|
||||
```py
|
||||
import time
|
||||
time_now = time.localtime() # полное время
|
||||
time_now
|
||||
time.struct_time(tm_year=2025, tm_mon=10, tm_mday=24, tm_hour=12, tm_min=13, tm_sec=23, tm_wday=4, tm_yday=297, tm_isdst=0)
|
||||
time_now = time.time() # время в секундах
|
||||
time_now
|
||||
1761296218.109631
|
||||
```
|
||||
Добавьте к этому времени 3 часа.
|
||||
Отобразите результат в виде: «Число секунд =ХХХХХ».
|
||||
```py
|
||||
time_new = time_now+(3*60*60) # 3 часа перевод в секунды
|
||||
print("Число секунд = ", time_new)
|
||||
Число секунд = 1761307018.109631
|
||||
```
|
||||
Создайте комплексное число, у которого вещественная и мнимая части – случайные, нормально распределенные числа с математическим ожиданием -55 и стандартным отклонением 12.
|
||||
|
||||
Извлеките из этого числа квадратный корень.
|
||||
|
||||
Отобразите результат в виде: «Результат = ХХХ+ХХj».
|
||||
|
||||
```py
|
||||
import random
|
||||
import cmath
|
||||
a = random.normalvariate(-55, 12) # случайные нормально распределенные числа с мат ожиданием -55, и стандартным отклонением 12.
|
||||
b = random.normalvariate(-55, 12)
|
||||
z = complex(a, b)
|
||||
z
|
||||
(-48.00248180546525-48.574962483174176j)
|
||||
sqr = cmath.sqrt(z)
|
||||
print('Результат = ', sqr.real, sqr.imag, 'j')
|
||||
Результат = 3.185065441113534 -7.625426130364191j
|
||||
```
|
||||
|
После Ширина: | Высота: | Размер: 114 KiB |
|
После Ширина: | Высота: | Размер: 43 KiB |
@ -0,0 +1,290 @@
|
||||
# Отчет по теме 5
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## 1. Открыла интерактивуню оболочку IDLE и создала файл отчета.
|
||||
|
||||
## 2. Ветвление по условию - управляющая конструкция if else
|
||||
Задали некоторые числовые значения объектам porog, rashod1, rashod2. Выполнили операцию
|
||||
для определения значения dohod:
|
||||
```py
|
||||
porog = 3
|
||||
rashod1 = 5
|
||||
rashod2 = 4
|
||||
|
||||
if rashod1>=porog:
|
||||
dohod=12
|
||||
elif rashod2==porog:
|
||||
dohod=0
|
||||
else:
|
||||
dohod=-8
|
||||
dohod
|
||||
12
|
||||
|
||||
if rashod1>=3 and rashod2==4:
|
||||
dohod=rashod1
|
||||
if rashod2==porog or rashod1<rashod2:
|
||||
dohod=porog
|
||||
|
||||
dohod
|
||||
5
|
||||
|
||||
if porog==3:
|
||||
dohod=1
|
||||
elif porog==4:
|
||||
dohod=2
|
||||
elif porog==5:
|
||||
dohod=3
|
||||
else:
|
||||
dohod=0
|
||||
|
||||
dohod
|
||||
1
|
||||
```
|
||||
Условные инструкции могут записываться также в одну строку в операторе присваивания по
|
||||
следующей схеме:
|
||||
<Объект>=<значение 1> if <условие> else <значение 2>
|
||||
или
|
||||
if <условие>: <инструкция1>[;<инструкция2>….]
|
||||
|
||||
```py
|
||||
dohod=2 if porog>=4 else 0
|
||||
dohod
|
||||
0
|
||||
if porog>=5 : rashod1=6; rashod2=0
|
||||
rashod1, rashod2
|
||||
(5, 4)
|
||||
```
|
||||
|
||||
## 3. Цикл по перечислению - управляющая констркуция for
|
||||
|
||||
### 3.1. Простой цикл
|
||||
|
||||
```py
|
||||
temperatura=5
|
||||
for i in range(3,18,3): # цикл от 3 до 18 с шагом 3
|
||||
temperatura+=i
|
||||
temperatura
|
||||
50
|
||||
```
|
||||
### 3.2. Более сложный цикл
|
||||
|
||||
```py
|
||||
sps=[2,15,14,8]
|
||||
for k in sps:
|
||||
if len(sps)<=10:sps.append(sps[0])
|
||||
else:break
|
||||
|
||||
sps
|
||||
[2, 15, 14, 8, 2, 2, 2, 2, 2, 2, 2]
|
||||
```
|
||||
### 3.3. Пример создания списка с 10 целыми случайными числами
|
||||
|
||||
```py
|
||||
for i in range(10):
|
||||
sps5.append(rn.randint(1,100))
|
||||
ss=sum(sps5)
|
||||
if ss>500: break
|
||||
else:
|
||||
print(ss)
|
||||
|
||||
sps5
|
||||
[27, 84, 92, 90, 10, 39, 46, 63, 88]
|
||||
ss
|
||||
539
|
||||
|
||||
# Вывод ss происходит только в случае если цикл for завершается самостоятельно без break т.е. ss < 500
|
||||
|
||||
for i in range(3):
|
||||
sps5.append(rn.randint(1,100))
|
||||
ss=sum(sps5)
|
||||
if ss>500: break
|
||||
else:
|
||||
print(ss)
|
||||
|
||||
186
|
||||
```
|
||||
### 3.4. Пример с символьной строкой
|
||||
|
||||
```py
|
||||
# цикл идет по каждому символу и сохраняет их в ss
|
||||
stroka='Это – автоматизированная система'
|
||||
stroka1=""
|
||||
for ss in stroka:
|
||||
stroka1+=" "+ss
|
||||
|
||||
stroka1
|
||||
' Э т о – а в т о м а т и з и р о в а н н а я с и с т е м а'
|
||||
```
|
||||
### 3.5. Запись цикла в строке.
|
||||
|
||||
```py
|
||||
import math
|
||||
sps2=[math.sin(i*math.pi/5+2) for i in range(100)]
|
||||
pylab.title('График синусоидального сигнала')
|
||||
pylab.plot(sps2)
|
||||
pylab.show()
|
||||
```
|
||||

|
||||
|
||||
## 4. Цикл "пока истинно условие" - управляющая конструкция While
|
||||
### 4.1 Цикл со счетчиком
|
||||
|
||||
```py
|
||||
rashod=300
|
||||
while rashod: # Цикл закончится когда rashod = 0
|
||||
print("Расход=",rashod)
|
||||
rashod-=50
|
||||
|
||||
Расход= 300
|
||||
Расход= 250
|
||||
Расход= 200
|
||||
Расход= 150
|
||||
Расход= 100
|
||||
Расход= 50
|
||||
```
|
||||
### 4.2. Пример с символьной строкой
|
||||
|
||||
```py
|
||||
import math
|
||||
stroka='Расчет процесса в объекте регулирования'
|
||||
i=0
|
||||
sps2=[]
|
||||
while i<len(stroka):
|
||||
r=1-2/(1+math.exp(0.1*i))
|
||||
sps2.append(r)
|
||||
print('Значение в момент',i,"=",r)
|
||||
i+=1
|
||||
Значение в момент 0 = 0.0
|
||||
Значение в момент 1 = 0.049958374957880025
|
||||
Значение в момент 2 = 0.09966799462495568
|
||||
Значение в момент 3 = 0.14888503362331795
|
||||
Значение в момент 4 = 0.197375320224904
|
||||
Значение в момент 5 = 0.2449186624037092
|
||||
Значение в момент 6 = 0.2913126124515909
|
||||
Значение в момент 7 = 0.3363755443363322
|
||||
Значение в момент 8 = 0.3799489622552249
|
||||
Значение в момент 9 = 0.421899005250008
|
||||
Значение в момент 10 = 0.4621171572600098
|
||||
Значение в момент 11 = 0.5005202111902354
|
||||
Значение в момент 12 = 0.5370495669980353
|
||||
Значение в момент 13 = 0.5716699660851172
|
||||
Значение в момент 14 = 0.6043677771171636
|
||||
Значение в момент 15 = 0.6351489523872873
|
||||
Значение в момент 16 = 0.6640367702678489
|
||||
Значение в момент 17 = 0.6910694698329307
|
||||
Значение в момент 18 = 0.7162978701990245
|
||||
Значение в момент 19 = 0.7397830512740043
|
||||
Значение в момент 20 = 0.7615941559557649
|
||||
Значение в момент 21 = 0.7818063576087741
|
||||
Значение в момент 22 = 0.8004990217606297
|
||||
Значение в момент 23 = 0.8177540779702878
|
||||
Значение в момент 24 = 0.8336546070121553
|
||||
Значение в момент 25 = 0.8482836399575129
|
||||
Значение в момент 26 = 0.8617231593133063
|
||||
Значение в момент 27 = 0.874053287886007
|
||||
Значение в момент 28 = 0.8853516482022625
|
||||
Значение в момент 29 = 0.8956928738431645
|
||||
Значение в момент 30 = 0.9051482536448664
|
||||
Значение в момент 31 = 0.9137854901178277
|
||||
Значение в момент 32 = 0.9216685544064713
|
||||
Значение в момент 33 = 0.9288576214547277
|
||||
Значение в момент 34 = 0.935409070603099
|
||||
Значение в момент 35 = 0.9413755384972874
|
||||
Значение в момент 36 = 0.9468060128462683
|
||||
Значение в момент 37 = 0.9517459571646616
|
||||
Значение в момент 38 = 0.9562374581277391
|
||||
```
|
||||
|
||||
Представим в виде графика
|
||||
|
||||
```py
|
||||
pylab.title('Сигнал на выходе инерционного звена')
|
||||
pylab.plot(sps2, color='violet')
|
||||
pylab.show()
|
||||
```
|
||||
|
||||

|
||||
|
||||
### 4.3. Определение является ли число простым
|
||||
|
||||
```py
|
||||
chislo=267 #Проверяемое число
|
||||
kandidat =chislo // 2 # Для значений chislo > 1
|
||||
while kandidat > 1:
|
||||
if chislo%kandidat == 0: # Остаток от деления
|
||||
print(chislo, ' имеет множитель ', kandidat)
|
||||
break # else выполняться не будет
|
||||
kandidat -= 1
|
||||
else: # При завершении цикла без break
|
||||
print(chislo, ' является простым!')
|
||||
|
||||
267 имеет множитель 89
|
||||
```
|
||||
|
||||
Выявим все простые числа от 250 до 300
|
||||
|
||||
```py
|
||||
for chislo in range(250,301):
|
||||
kandidat = chislo // 2
|
||||
while kandidat > 1:
|
||||
if chislo%kandidat == 0: # Остаток от деления
|
||||
print(chislo, ' имеет множитель ', kandidat)
|
||||
break # else выполняться не будет
|
||||
kandidat -= 1
|
||||
else: # При завершении цикла без break
|
||||
print(chislo, ' является простым!')
|
||||
|
||||
|
||||
250 имеет множитель 125
|
||||
251 является простым!
|
||||
252 имеет множитель 126
|
||||
253 имеет множитель 23
|
||||
254 имеет множитель 127
|
||||
255 имеет множитель 85
|
||||
256 имеет множитель 128
|
||||
257 является простым!
|
||||
258 имеет множитель 129
|
||||
259 имеет множитель 37
|
||||
260 имеет множитель 130
|
||||
261 имеет множитель 87
|
||||
262 имеет множитель 131
|
||||
263 является простым!
|
||||
264 имеет множитель 132
|
||||
265 имеет множитель 53
|
||||
266 имеет множитель 133
|
||||
267 имеет множитель 89
|
||||
268 имеет множитель 134
|
||||
269 является простым!
|
||||
270 имеет множитель 135
|
||||
271 является простым!
|
||||
272 имеет множитель 136
|
||||
273 имеет множитель 91
|
||||
274 имеет множитель 137
|
||||
275 имеет множитель 55
|
||||
276 имеет множитель 138
|
||||
277 является простым!
|
||||
278 имеет множитель 139
|
||||
279 имеет множитель 93
|
||||
280 имеет множитель 140
|
||||
281 является простым!
|
||||
282 имеет множитель 141
|
||||
283 является простым!
|
||||
284 имеет множитель 142
|
||||
285 имеет множитель 95
|
||||
286 имеет множитель 143
|
||||
287 имеет множитель 41
|
||||
288 имеет множитель 144
|
||||
289 имеет множитель 17
|
||||
290 имеет множитель 145
|
||||
291 имеет множитель 97
|
||||
292 имеет множитель 146
|
||||
293 является простым!
|
||||
294 имеет множитель 147
|
||||
295 имеет множитель 59
|
||||
296 имеет множитель 148
|
||||
297 имеет множитель 99
|
||||
298 имеет множитель 149
|
||||
299 имеет множитель 23
|
||||
300 имеет множитель 150
|
||||
```
|
||||
## 5. Завершила работу со средой и сохранила файл отчета.
|
||||
@ -0,0 +1,94 @@
|
||||
# Общее контрольное задание по теме 5
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
Реализовать, записать в текстовый файл программы и результаты их выполнения при решении
|
||||
следующих задач:
|
||||
|
||||
1. Для заданной символьной строки с англоязычным текстом определите порядковый номер каждой буквы в английском алфавите.
|
||||
|
||||
```py
|
||||
alphabet = "abcdefghijklmnopqrstuvwxyz"
|
||||
for letter in alphabet:
|
||||
if letter.isalpha():
|
||||
position = ord(letter) - 96
|
||||
print(letter, ' Номер буквы: ', position)
|
||||
a Номер буквы: 1
|
||||
b Номер буквы: 2
|
||||
c Номер буквы: 3
|
||||
d Номер буквы: 4
|
||||
e Номер буквы: 5
|
||||
f Номер буквы: 6
|
||||
g Номер буквы: 7
|
||||
h Номер буквы: 8
|
||||
i Номер буквы: 9
|
||||
j Номер буквы: 10
|
||||
k Номер буквы: 11
|
||||
l Номер буквы: 12
|
||||
m Номер буквы: 13
|
||||
n Номер буквы: 14
|
||||
o Номер буквы: 15
|
||||
p Номер буквы: 16
|
||||
q Номер буквы: 17
|
||||
r Номер буквы: 18
|
||||
s Номер буквы: 19
|
||||
t Номер буквы: 20
|
||||
u Номер буквы: 21
|
||||
v Номер буквы: 22
|
||||
w Номер буквы: 23
|
||||
x Номер буквы: 24
|
||||
y Номер буквы: 25
|
||||
z Номер буквы: 26
|
||||
```
|
||||
2. Создайте список со словами из задания данного пункта. Для этого списка – определите, есть ли
|
||||
в нем некоторое заданное значение, и выведите соответствующее сообщение: либо о
|
||||
нахождении элемента, либо о его отсутствии в списке (проверить как с имеющимся, так и с
|
||||
отсутствующим словом).
|
||||
|
||||
```py
|
||||
stroka = '''Создайте список со словами из задания данного пункта. Для этого списка – определите, есть ли
|
||||
в нем некоторое заданное значение, и выведите соответствующее сообщение: либо о
|
||||
нахождении элемента, либо о его отсутствии в списке (проверить как с имеющимся, так и с
|
||||
отсутствующим словом).'''
|
||||
if 'привет' in stroka:
|
||||
print('такое слово есть')
|
||||
else:
|
||||
print('такого слова не нашлось(')
|
||||
|
||||
такого слова не нашлось(
|
||||
|
||||
if 'список' in stroka:
|
||||
print('такое слово есть')
|
||||
else:
|
||||
print('такого слова не нашлось(')
|
||||
|
||||
такое слово есть
|
||||
```
|
||||
|
||||
3. Создайте список студентов вашей группы (3-4 фамилии) и список их средних баллов в летней
|
||||
сессии – в порядке перечисления студентов в первом списке. Создайте еще 2 аналогичных
|
||||
списка для тех же студентов, но в другом порядке, по зимней сессии. Напишите инструкции,
|
||||
позволяющие по указанной (запрошенной и введенной) фамилии студента вывести его средние баллы по двум сессиям
|
||||
|
||||
|
||||
```py
|
||||
familii = ['Антонов', 'Девятова', 'Ефимова']
|
||||
marks_summer = [5,5,4]
|
||||
familii2 = ['Ефимова', 'Антонов', 'Девятова']
|
||||
marks_winter = [4,5,5]
|
||||
name = input('Введите фамилию: ')
|
||||
Введите фамилию: Антонов
|
||||
|
||||
for name in familii:
|
||||
result = (marks_summer[familii.index(name)] + marks_winter[familii2.index(name)])/2
|
||||
print('Средний балл: ', result)
|
||||
break
|
||||
|
||||
Средний балл: 5.0
|
||||
```
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@ -0,0 +1,33 @@
|
||||
# Индивидуальное контрольное задание вариант 25
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## Задание
|
||||
Создайте список с 50 элементами – целыми случайными числами из диапазона значений от -1 до +1.
|
||||
|
||||
```py
|
||||
import random
|
||||
for i in range(50):
|
||||
sps.append(random.randint(-1, 1))
|
||||
sps
|
||||
[1, 0, 0, 1, -1, -1, 1, 1, 0, -1, -1, -1, 0, 1, 1, -1, -1, -1, 0, 0, -1, 1, 0, -1, 1, -1, 1, 0, 0, -1, 0, 1, 0, 0, 1, -1, 1, 0, 0, -1, 0, -1, 0, -1, 1, 1, -1, -1, 1, 1]
|
||||
```
|
||||
|
||||
Определите по этому списку, сколько раз последующее число было меньше предыдущего, сколько – больше и сколько – равным.
|
||||
Отобразите результат в виде строки: «Больше=ХХ, меньше=ХХ, равно=ХХ».
|
||||
|
||||
```py
|
||||
big = 0 # счетчики
|
||||
small =0
|
||||
equal = 0
|
||||
for i in range(len(sps)-1):
|
||||
current = sps[i]
|
||||
next_num = sps[i+1]
|
||||
if next_num < current:
|
||||
small += 1
|
||||
elif next_num > current:
|
||||
big += 1
|
||||
else: equal += 1
|
||||
|
||||
print('Больше =', big, ' Меньше =', small, ' Равно = ', equal)
|
||||
Больше = 16 Меньше = 18 Равно = 33
|
||||
```
|
||||
@ -0,0 +1,373 @@
|
||||
# Отчет по теме 6
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## 1. Запустила интерактивную оболочку и создала файл отчета
|
||||
|
||||
## 2. Вывод данных на экран дисплея
|
||||
### 2.1. Вывод в командной строке
|
||||
Эхо-вывод строки. Нельзя использовать в пользовательских функциях.
|
||||
|
||||
```py
|
||||
stroka='Автоматизированная система управления'
|
||||
stroka
|
||||
'Автоматизированная система управления'
|
||||
```
|
||||
|
||||
### 2.2. Вывод с использованием функции print
|
||||
|
||||
```py
|
||||
fff=234.5;gg='Значение температуры = '
|
||||
print(gg, fff) #Можно вывести несколько объектов за одно обращение к функции
|
||||
Значение температуры = 234.5
|
||||
print(gg, fff, sep='/') # изменили разделитель по умолчанию на /
|
||||
Значение температуры = /234.5
|
||||
```
|
||||
После вывода автоматически осуществляется переход на другую строку. Если курсор надо
|
||||
оставить в той же строке, то следует использовать еще один аргумент.
|
||||
После end указано какими символами кончается строка
|
||||
```py
|
||||
print(gg, fff,sep='/',end='***'); print('____')
|
||||
Значение температуры = /234.5***____
|
||||
```
|
||||
Оператор вывода может располагаться на нескольких строках с использованием
|
||||
тройных кавычек
|
||||
```py
|
||||
print(""" Здесь может выводиться
|
||||
большой текст,
|
||||
занимающий несколько строк""")
|
||||
Здесь может выводиться
|
||||
большой текст,
|
||||
занимающий несколько строк
|
||||
print("Здесь может выводиться",
|
||||
"большой текст,",
|
||||
"занимающий несколько строк")
|
||||
Здесь может выводиться большой текст, занимающий несколько строк
|
||||
```
|
||||
### 2.3. Вывод с использованием метода write объекта sys.stdout.
|
||||
stdout представляет собой
|
||||
поток стандартного вывода – объект, в который программы выводят символьное представление данных.
|
||||
|
||||
```py
|
||||
import sys
|
||||
sys.stdout.write('Функция write')
|
||||
Функция write13
|
||||
sys.stdout.write('Функция write\n') # \n перенос на следующую строку
|
||||
Функция write
|
||||
14
|
||||
```
|
||||
|
||||
## 3. Ввод данных с клавиатуры
|
||||
|
||||
```py
|
||||
psw=input('Введите пароль:')
|
||||
Введите пароль: 1234
|
||||
psw
|
||||
' 1234'
|
||||
type(psw)
|
||||
<class 'str'>
|
||||
```
|
||||
Ввод с контролем значения
|
||||
```py
|
||||
while True:
|
||||
znach=float(input('Задайте коэф.усиления = '))
|
||||
if znach<17.5 or znach>23.8:
|
||||
print('Ошибка!')
|
||||
else:
|
||||
break
|
||||
|
||||
Задайте коэф.усиления = 4
|
||||
Ошибка!
|
||||
Задайте коэф.усиления = 20
|
||||
```
|
||||
Вывод и обработка выражения, подлежащего расчету
|
||||
|
||||
```py
|
||||
import math
|
||||
print(eval(input('введите выражение для расчета = ')))
|
||||
введите выражение для расчета = math.log10(23/(1+math.exp(-3.24)))
|
||||
1.34504378689765
|
||||
```
|
||||
## 4. Ввод-вывод данных при работе с файлами
|
||||
Работа с файлом требует указания источника данных - полного имени файла с путем доступа к его расположению.
|
||||
|
||||
### 4.1. Функции для работы с путем к файлу
|
||||
```py
|
||||
os.getcwd ()
|
||||
'C:\\Users\\Людмила\\AppData\\Local\\Programs\\Python\\Python313'
|
||||
way = os.getcwd() # сохранили путь в переменную
|
||||
way
|
||||
'C:\\Users\\Людмила\\AppData\\Local\\Programs\\Python\\Python313'
|
||||
```
|
||||
Установили новый рабочий каталог
|
||||
```py
|
||||
os.chdir('H:\\study\\ПОАС')
|
||||
os.getcwd ()
|
||||
'H:\\study\\ПОАС'
|
||||
```
|
||||
В модуле os также есть функции, позволяющие удалять и создавать директории.
|
||||
|
||||
```py
|
||||
os.listdir() #Возвращает список имен файлов находящихся в рабочей директории
|
||||
['New directory', 'report — копия.odt', 'report3.md', 'report4.md', 'report5.md', 'report6.txt', 'Ris1.png', 'Ris2.png', 'task.md', 'task3.md', 'task4.md', 'Методические указания по ПОАС.pdf', 'репозиторий', 'Тест по модулю 1 ПОАС.docx']
|
||||
os.path.isdir("New directory"); os.path.isdir("test333") # Проверка наличия директории в рабочем каталоге
|
||||
True
|
||||
False
|
||||
os.rmdir('New directory') # Удаление директории
|
||||
os.listdir()
|
||||
['report — копия.odt', 'report3.md', 'report4.md', 'report5.md', 'report6.txt', 'Ris1.png', 'Ris2.png', 'task.md', 'task3.md', 'task4.md', 'Методические указания по ПОАС.pdf', 'репозиторий', 'Тест по модулю 1 ПОАС.docx']
|
||||
```
|
||||
Можно также получить путь к файлу
|
||||
|
||||
```py
|
||||
fil=os.path.abspath("report5.md")
|
||||
fil
|
||||
'H:\\study\\ПОАС\\report5.md'
|
||||
drkt = os.path.dirname(fil)
|
||||
drkt
|
||||
'H:\\study\\ПОАС'
|
||||
name = os.path.basename(fil) # Выделение имени файла
|
||||
name
|
||||
'report5.md'
|
||||
directory, fileName = os.path.split(fil) # Разделяет путь к файлу на путь доступа к файлу и его имя (Возвращает кортеж из этих двух составляющих)
|
||||
print(directory);print(fileName)
|
||||
H:\study\ПОАС
|
||||
report5.md
|
||||
```
|
||||
Проверка указывает ли путь к нужному файлу
|
||||
|
||||
```py
|
||||
os.path.isfile(fil) # Проверка пути к файлу
|
||||
True
|
||||
os.path.isfile("test.txt")
|
||||
False
|
||||
```
|
||||
### 4.2. Общая схема работы с файлами
|
||||
|
||||
Для обмена данными с файлом необходимо выполнить следующие операции:
|
||||
Открытие файла с указанием его имени и цели (чтение, запись, добавление данных);
|
||||
|
||||
Выполнение одной или нескольких операций обмена данными с файлом;
|
||||
|
||||
Закрытие файла.
|
||||
|
||||
### 4.3. Открытие файла для записи или чтения данных - функция open
|
||||
При открытии файла необходимо указать имя файлы (с путем, если он не в рабочем каталоге) и цель работы с ним.
|
||||
fp – это файловый объект, сохраняет ссылку на открываемый файл.
|
||||
|
||||
w – запись с созданием нового файла или перезапись существующего файла,
|
||||
w+ - чтение и запись/перезапись файла,
|
||||
r – только чтение (это значение - по умолчанию),
|
||||
r+ - чтение и/или запись в существующий файл,
|
||||
a – запись в конец существующего файла или, если его нет, запись с созданием файла,
|
||||
a+ - то же, что и в «a», но с возможностью чтения из файла.
|
||||
|
||||
```py
|
||||
fp=open(file=drkt+'\\zapis1.txt',mode='w') # открыли файл для записи данных
|
||||
fp=open(drkt+'\\zapis1.txt','w') # имена аргументов можно опустить
|
||||
fp=open('zapis1.txt','w') # Открытие файла, путь к которому совпадает с рабочим каталогом
|
||||
|
||||
type(fp)
|
||||
<class '_io.TextIOWrapper'>
|
||||
dir(fp)
|
||||
['_CHUNK_SIZE', '__class__', '__del__', '__delattr__', '__dict__', '__dir__', '__doc__', '__enter__', '__eq__', '__exit__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__next__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '_checkClosed', '_checkReadable', '_checkSeekable', '_checkWritable', '_finalizing', 'buffer', 'close', 'closed', 'detach', 'encoding', 'errors', 'fileno', 'flush', 'isatty', 'line_buffering', 'mode', 'name', 'newlines', 'read', 'readable', 'readline', 'readlines', 'reconfigure', 'seek', 'seekable', 'tell', 'truncate', 'writable', 'write', 'write_through', 'writelines']
|
||||
```
|
||||
### 4.4. Закрытие файла
|
||||
```py
|
||||
fp.close()
|
||||
```
|
||||
|
||||
### 4.5. Запись информации в файл
|
||||
Можно записать информацию в файл с помощью метода write
|
||||
|
||||
```py
|
||||
sps=list(range(1,13))
|
||||
sps
|
||||
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
|
||||
fp2 = open("zapis3.txt", "w") # запись первых 4 значений и перенос строки
|
||||
fp2.write(str(sps[:4])+'\n')
|
||||
13
|
||||
fp2.write(str(sps[4:8])+'\n')
|
||||
13
|
||||
fp2.write(str(sps[8:])+'\n')
|
||||
16
|
||||
fp2.close()
|
||||
```
|
||||
Содержимое файла
|
||||
```py
|
||||
[1, 2, 3, 4]
|
||||
[5, 6, 7, 8]
|
||||
[9, 10, 11, 12]
|
||||
```
|
||||
Запись данных внутри цикла
|
||||
```py
|
||||
sps3 = [["Иванов И.", 1], ["Петров П.", 2], ["Сидоров С.", 3]]
|
||||
for i in range(len(sps3)):
|
||||
stroka4=sps3[i][0]+' '+str(sps3[i][1])
|
||||
fp3.write(stroka4)
|
||||
|
||||
11
|
||||
11
|
||||
12
|
||||
fp3.close()
|
||||
```
|
||||
Содержимое файла
|
||||
```py
|
||||
Иванов И. 1Петров П. 2Сидоров С. 3
|
||||
```
|
||||
Запишем иначе
|
||||
```py
|
||||
fp3=open('zapis5.txt','w')
|
||||
for r in sps3:
|
||||
fp3.write(r[0]+' '+str(r[1])+'\n')
|
||||
|
||||
12
|
||||
12
|
||||
13
|
||||
for r in sps3: fp3.write(r[0]+' '+str(r[1])+'\n') # в одну строку
|
||||
12
|
||||
12
|
||||
13
|
||||
```
|
||||
Содержимое файла
|
||||
```py
|
||||
Иванов И. 1
|
||||
Петров П. 2
|
||||
Сидоров С. 3
|
||||
```
|
||||
|
||||
### 4.6. Чтение информации из текстового файла внутри цикла.
|
||||
Чтение данных из файла происходит последовательно, начиная с некоторого символа. В качестве примера прочитан ранее созданный файл zapis3.txt:
|
||||
```py
|
||||
fp=open('zapis3.txt')
|
||||
for stroka in fp:
|
||||
stroka=stroka.rstrip('\n')
|
||||
stroka=stroka.replace('[','')
|
||||
stroka=stroka.replace(']','')
|
||||
sps1=sps1+stroka.split(',')
|
||||
|
||||
fp.close()
|
||||
sps1
|
||||
['1', ' 2', ' 3', ' 4', '5', ' 6', ' 7', ' 8', '9', ' 10', ' 11', ' 12']
|
||||
```
|
||||
Сделаем чтобы элементы совпадали с исходными
|
||||
|
||||
```py
|
||||
for i in range(len(sps1)):
|
||||
sps1[i] = int(sps1[i])
|
||||
sps1
|
||||
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
|
||||
```
|
||||
### 4.7. Чтение информации с помощью метода read
|
||||
Метод read, также как и write, относится к объекту - файловой переменной.
|
||||
|
||||
```py
|
||||
fp=open('zapis3.txt')
|
||||
stroka1=fp.read(12)
|
||||
stroka2=fp.read()
|
||||
fp.close()
|
||||
stroka2
|
||||
'\n[5, 6, 7, 8]\n[9, 10, 11, 12]\n'
|
||||
stroka1
|
||||
'[1, 2, 3, 4]'
|
||||
```
|
||||
### 4.8. Чтение информации с помощью методов readline и readlines
|
||||
|
||||
```py
|
||||
fp = open("zapis3.txt")
|
||||
stroka1 = fp.readline() # Чтение первой строки файла
|
||||
stroka2 = fp.readline() # Чтение второй строки файла
|
||||
fp.close()
|
||||
fp = open("zapis3.txt")
|
||||
stroka3 = fp.readlines() # Чтение всех строк файла
|
||||
fp.close()
|
||||
stroka1
|
||||
'[1, 2, 3, 4]\n'
|
||||
stroka2
|
||||
'[5, 6, 7, 8]\n'
|
||||
stroka3
|
||||
['[1, 2, 3, 4]\n', '[5, 6, 7, 8]\n', '[9, 10, 11, 12]\n']
|
||||
```
|
||||
### 4.9. Ввод-вывод объектов с использованием функций из модуля pickle.
|
||||
Для работы с бинарными файлами можно пользоваться функциями из модуля pickle. Примером этого может послужить запись объекта-множества в бинарный файл:
|
||||
```py
|
||||
import pickle
|
||||
mnoz1={'pen','book','pen','iPhone','table','book'} #Объект типа «множество»
|
||||
fp=open('zapis6.mnz','wb') # Бинарный файл – на запись
|
||||
pickle.dump(mnoz1,fp) #dump – метод записи объекта в файл
|
||||
fp.close()
|
||||
|
||||
fp=open('zapis6.mnz','rb')
|
||||
mnoz2=pickle.load(fp) #load – метод чтения объекта из бинарного файла
|
||||
fp.close()
|
||||
mnoz1
|
||||
{'iPhone', 'pen', 'book', 'table'}
|
||||
mnoz2
|
||||
{'pen', 'table', 'book', 'iPhone'}
|
||||
mnoz2 == mnoz1
|
||||
True
|
||||
```
|
||||
Получение объекта из файла можно осуществить с помощью метода load:
|
||||
|
||||
```py
|
||||
fp = open("zapis6.mnz", "rb")
|
||||
mnoz2 = pickle.load(fp) # Получение объекта из файла
|
||||
fp.close()
|
||||
fp = open("zapis7.2ob", "wb")
|
||||
pickle.dump(mnoz1, fp)
|
||||
pickle.dump(sps3, fp)
|
||||
fp.close()
|
||||
fp = open("zapis7.2ob", "rb")
|
||||
obj1 = pickle.load(fp) # Получение объекта, записанного первым
|
||||
obj2 = pickle.load(fp) # Получение объекта, записанного вторым
|
||||
fp.close()
|
||||
obj1
|
||||
{'pen', 'table', 'book', 'iPhone'}
|
||||
obj2
|
||||
[['Иванов И.', 1], ['Петров П.', 2], ['Сидоров С.', 3]]
|
||||
```
|
||||
## 5. Перенаправление потоков ввода и вывода данных.
|
||||
Потоки ввода-вывода можно перенаправлять, например в файл:
|
||||
|
||||
```py
|
||||
import sys
|
||||
vr_out = sys.stdout # Сохранение текущего потока вывода
|
||||
fc = open("Stroka.txt", "w")
|
||||
sys.stdout = fc # Перезапись потока вывода с экрана на файл
|
||||
print("Запись строки в файл")
|
||||
fc.close()
|
||||
sys.stdout = vr_out # Возвращение истинного значения потока вывода
|
||||
print("Запись строки на экран")
|
||||
Запись строки на экран
|
||||
```
|
||||
Содержимое файла
|
||||
|
||||
```py
|
||||
Запись строки в файл
|
||||
```
|
||||
Точно также можно перенаправить поток ввода – sys.stdin – вместо клавиатуры – из файла.
|
||||
|
||||
```py
|
||||
tmp_in = sys.stdin # Сохранение текущего потока ввода
|
||||
fd = open("Stroka.txt", "r") # Открываем файл для ввода (чтения)
|
||||
sys.stdin = fd # Перенацеливаем ввод на файл вместо клавиатуры
|
||||
sys.stdin
|
||||
<_io.TextIOWrapper name='Stroka.txt' mode='r' encoding='cp1251'>
|
||||
while True:
|
||||
try:
|
||||
line = input() # Чтение строки из файла
|
||||
print(line)
|
||||
except EOFError:
|
||||
break
|
||||
|
||||
|
||||
Запись строки в файл
|
||||
|
||||
fd.close()
|
||||
```
|
||||
## 6. Завершила работу со средой
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@ -0,0 +1,90 @@
|
||||
# Общее контрольное задание по теме 6
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
Создаётся объект-кортеж со 125 целыми случайными числами из диапазона от 6 до 56,
|
||||
представленными в виде символьных строк.
|
||||
|
||||
```py
|
||||
import random as rn
|
||||
kort = tuple(str(rn.randint(6, 56)) for i in range(126))
|
||||
kort
|
||||
('42', '36', '38', '37', '20', '52', '26', '16', '21', '41', '7', '18', '56', '40', '16', '40', '10', '55', '13', '44', '26', '11', '49', '29', '51', '37', '11', '32', '51', '50', '22', '25', '6', '11', '17', '36', '34', '10', '35', '45', '36', '34', '30', '28', '13', '50', '53', '19', '54', '30', '55', '33', '27', '46', '33', '55', '41', '26', '44', '18', '51', '52', '13', '23', '38', '34', '9', '6', '18', '12', '37', '30', '46', '10', '40', '46', '20', '18', '7', '14', '38', '11', '16', '50', '31', '22', '37', '6', '34', '38', '11', '44', '27', '10', '35', '39', '10', '50', '47', '24', '29', '6', '38', '50', '15', '56', '9', '22', '55', '10', '17', '14', '8', '34', '37', '28', '50', '22', '41', '10', '34', '34', '9', '8', '18', '40')
|
||||
```
|
||||
|
||||
Создаётся объект-список с вашей фамилией и 4 фамилиями ваших одноклассников.
|
||||
```py
|
||||
sps = ['Ефимова', 'Антонов', 'Девятова', 'Гордиевских']
|
||||
```
|
||||
|
||||
Записывается кортеж в бинарный файл.
|
||||
Записывается в этот же файл список и закрывается файл.
|
||||
```py
|
||||
import pickle
|
||||
import os
|
||||
os.chdir('H:\\study\\ПОАС')
|
||||
fp = open('task.bin', 'wb')
|
||||
pickle.dump(kort, fp)
|
||||
```
|
||||
Открывается этот файл для чтения и считывает из него данные в 2 новых объекта.
|
||||
```py
|
||||
pickle.dump(sps, fp)
|
||||
fp.close()
|
||||
```
|
||||
Проверяется на совпадение новых объектов с исходными и выводится соответствующее
|
||||
сообщение.
|
||||
```py
|
||||
fp = open("task.bin", "rb")
|
||||
newKort = pickle.load(fp)
|
||||
obj1=pickle.load(fp)
|
||||
fp.close()
|
||||
newKort == kort; obj1 == sps
|
||||
True
|
||||
True
|
||||
newKort
|
||||
('42', '36', '38', '37', '20', '52', '26', '16', '21', '41', '7', '18', '56', '40', '16', '40', '10', '55', '13', '44', '26', '11', '49', '29', '51', '37', '11', '32', '51', '50', '22', '25', '6', '11', '17', '36', '34', '10', '35', '45', '36', '34', '30', '28', '13', '50', '53', '19', '54', '30', '55', '33', '27', '46', '33', '55', '41', '26', '44', '18', '51', '52', '13', '23', '38', '34', '9', '6', '18', '12', '37', '30', '46', '10', '40', '46', '20', '18', '7', '14', '38', '11', '16', '50', '31', '22', '37', '6', '34', '38', '11', '44', '27', '10', '35', '39', '10', '50', '47', '24', '29', '6', '38', '50', '15', '56', '9', '22', '55', '10', '17', '14', '8', '34', '37', '28', '50', '22', '41', '10', '34', '34', '9', '8', '18', '40')
|
||||
obj1
|
||||
['Ефимова', 'Антонов', 'Девятова', 'Гордиевских']
|
||||
```
|
||||
Разделяется кортеж на совокупности по 5 чисел в каждой и они записываются в виде
|
||||
отдельных списков со своими именами.
|
||||
```py
|
||||
a={}
|
||||
for i in range(0, len(kort), 5):
|
||||
a['группа ' + str(i//5)] = list(kort[i:i+5])
|
||||
|
||||
for group_name, numbers in a.items():
|
||||
print(f"{group_name}: {numbers}")
|
||||
|
||||
|
||||
группа0: ['42', '36', '38', '37', '20']
|
||||
группа1: ['52', '26', '16', '21', '41']
|
||||
группа2: ['7', '18', '56', '40', '16']
|
||||
группа3: ['40', '10', '55', '13', '44']
|
||||
группа4: ['26', '11', '49', '29', '51']
|
||||
группа5: ['37', '11', '32', '51', '50']
|
||||
группа6: ['22', '25', '6', '11', '17']
|
||||
группа7: ['36', '34', '10', '35', '45']
|
||||
группа8: ['36', '34', '30', '28', '13']
|
||||
группа9: ['50', '53', '19', '54', '30']
|
||||
группа10: ['55', '33', '27', '46', '33']
|
||||
группа11: ['55', '41', '26', '44', '18']
|
||||
группа12: ['51', '52', '13', '23', '38']
|
||||
группа13: ['34', '9', '6', '18', '12']
|
||||
группа14: ['37', '30', '46', '10', '40']
|
||||
группа15: ['46', '20', '18', '7', '14']
|
||||
группа16: ['38', '11', '16', '50', '31']
|
||||
группа17: ['22', '37', '6', '34', '38']
|
||||
группа18: ['11', '44', '27', '10', '35']
|
||||
группа19: ['39', '10', '50', '47', '24']
|
||||
группа20: ['29', '6', '38', '50', '15']
|
||||
группа21: ['56', '9', '22', '55', '10']
|
||||
группа22: ['17', '14', '8', '34', '37']
|
||||
группа23: ['28', '50', '22', '41', '10']
|
||||
группа24: ['34', '34', '9', '8', '18']
|
||||
группа25: ['40']
|
||||
```
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@ -0,0 +1,55 @@
|
||||
# Индивидуальное контрольное задание вариант 11
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
Запросите у пользователя и введите имя функции из библиотеки math для обработки данных.
|
||||
```py
|
||||
import math
|
||||
import os
|
||||
import pickle
|
||||
import random
|
||||
|
||||
func = input("Имя функции из модуля math: ")
|
||||
Имя функции из модуля math: sqrt
|
||||
func1 = getattr(math, func)
|
||||
```
|
||||
|
||||
Создайте кортеж с 20 случайными равномерно распределенными числами из диапазона значений от 11 до 40.
|
||||
```py
|
||||
data = tuple(random.uniform(11, 40) for i in range(20))
|
||||
print(data)
|
||||
(27.586471737691216, 21.881793540024304, 32.028176641070715, 13.113820051694203, 26.94302061378759, 37.26299607155637, 19.024847631740833, 29.51898579825734, 11.113814609881052, 24.804710396240207, 14.220720732639323, 23.141556713603123, 25.602521683956827, 29.559769008668546, 15.73803346599436, 23.54457430801797, 22.29227709666803, 33.30664014943534, 38.76321330079019, 17.242719629575422)
|
||||
```
|
||||
|
||||
Напишите инструкцию создания списка, содержащего значения, равные результаты вычисления заданной пользователем функции от соответствующих элементов кортежа.
|
||||
```py
|
||||
result = [func1(i) for i in data]
|
||||
print(result)
|
||||
[5.252282526453734, 4.6777979370665745, 5.659344188249263, 3.6213008783715006, 5.190666682978939, 6.104342394685637, 4.361748231127152, 5.433137748875629, 3.3337388334842686, 4.980432751904217, 3.7710370897989485, 4.8105671925047595, 5.059893445909393, 5.436889644702065, 3.9671190385460275, 4.85227516820903, 4.72146980257928, 5.771190531375249, 6.226011026394845, 4.152435385358262]
|
||||
```
|
||||
|
||||
Выведите кортеж и результирующий список в бинарный файл с любым именем.
|
||||
```py
|
||||
os.chdir('L:\\III курс\\А-3-23\\Efimova lyudmila')
|
||||
fp = open('test1.bin', 'wb')
|
||||
pickle.dump(result, fp)
|
||||
```
|
||||
|
||||
Рассчитайте среднее значение разностей элементов списка, находящихся на соседних четных и нечетных позициях.
|
||||
Отобразите результат на экране.
|
||||
```py
|
||||
for i in range(1, len(result), 2):
|
||||
diff = [result[i] - result[i-1]]
|
||||
average = sum(diff)/len(diff)
|
||||
print('Среднее значение разностей: ', average)
|
||||
|
||||
Среднее значение разностей: -0.5744845893871595
|
||||
Среднее значение разностей: -2.0380433098777626
|
||||
Среднее значение разностей: 0.9136757117066976
|
||||
Среднее значение разностей: 1.0713895177484778
|
||||
Среднее значение разностей: 1.646693918419948
|
||||
Среднее значение разностей: 1.039530102705811
|
||||
Среднее значение разностей: 0.3769961987926722
|
||||
Среднее значение разностей: 0.8851561296630028
|
||||
Среднее значение разностей: 1.0497207287959691
|
||||
Среднее значение разностей: -2.073575641036583
|
||||
```
|
||||
|
После Ширина: | Высота: | Размер: 17 KiB |
|
После Ширина: | Высота: | Размер: 22 KiB |
@ -0,0 +1,490 @@
|
||||
# Отчет по теме 7
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
# Создание пользовательских функций
|
||||
## 1. Настройка текущего каталога
|
||||
|
||||
```py
|
||||
import os
|
||||
os.chdir("H:\\study\\ПОАС")
|
||||
```
|
||||
## 2. Создание пользовательской функции
|
||||
Создание функции предполагает выполнение трех операций: формирование функции, ее
|
||||
сохранение и использование.
|
||||
|
||||
### 2.1. Пример функции без аргументов
|
||||
|
||||
```py
|
||||
def uspeh():
|
||||
"""Подтверждение успеха операции"""
|
||||
print('Выполнено успешно!')
|
||||
uspeh()
|
||||
Выполнено успешно!
|
||||
type(uspeh)
|
||||
<class 'function'>
|
||||
dir() # убедились что функция появилась в пространстве имен
|
||||
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'os', 'uspeh']
|
||||
help(uspeh) # инструкция выводит описание функции, указанное в тройных кавычках
|
||||
Help on function uspeh in module __main__:
|
||||
|
||||
uspeh()
|
||||
Подтверждение успеха операции
|
||||
```
|
||||
### 2.2. Пример функции с аргументами
|
||||
|
||||
```py
|
||||
def sravnenie(a,b):
|
||||
"""Сравнение a и b"""
|
||||
if a>b:
|
||||
print(a,' больше ',b)
|
||||
elif a<b:
|
||||
print(a, ' меньше ',b)
|
||||
else:
|
||||
print(a, ' равно ',b)
|
||||
|
||||
n,m=16,5;sravnenie(n,m)
|
||||
16 больше 5
|
||||
|
||||
n,m="привет","пока";sravnenie(n,m) # сравнение символьных строк
|
||||
привет больше пока
|
||||
```
|
||||
### 2.3. Пример функции, содержащей return.
|
||||
|
||||
```py
|
||||
def logistfun(b,a):
|
||||
"""Вычисление логистической функции"""
|
||||
import math
|
||||
return a/(1+math.exp(-b))
|
||||
|
||||
v,w=1,0.7;z=logistfun(w,v)
|
||||
z
|
||||
0.6681877721681662
|
||||
```
|
||||
### 2.4. Сложение для разных типов аргументов
|
||||
|
||||
```py
|
||||
def slozh(a1,a2,a3,a4):
|
||||
""" Сложение значений четырех аргументов"""
|
||||
return a1+a2+a3+a4
|
||||
|
||||
slozh(1,2,3,4) # Сложение чисел
|
||||
10
|
||||
|
||||
slozh('1','2','3','4') # Сложение строк
|
||||
'1234'
|
||||
b1=[1,2];b2=[-1,-2];b3=[0,2];b4=[-1,-1]
|
||||
|
||||
q=slozh(b1,b2,b3,b4) #Сложение списков
|
||||
q
|
||||
[1, 2, -1, -2, 0, 2, -1, -1]
|
||||
|
||||
slozh((1, 2), (3, 4), (-1, -2), (-3,-4)) #Сложение кортежей
|
||||
(1, 2, 3, 4, -1, -2, -3, -4)
|
||||
|
||||
slozh({1,2,3,4}, {'pym', True, 'pyrym', False}, {"l", "a", "n", 13}, {"hi", "i", "miss", "you"}) #Сложение множеств
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#31>", line 1, in <module>
|
||||
slozh({1,2,3,4}, {'pym', True, 'pyrym', False}, {"l", "a", "n", 13}, {"hi", "i", "miss", "you"}) #Сложение множеств
|
||||
File "<pyshell#23>", line 3, in slozh
|
||||
return a1+a2+a3+a4
|
||||
TypeError: unsupported operand type(s) for +: 'set' and 'set'
|
||||
dict1 = {'a': 1}; dict2 = {'b': 2}; dict3 = {'c': 3}; dict4 = {'d': 4}
|
||||
|
||||
slozh(dict1, dict2, dict3, dict4) #Сложение словарей
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#33>", line 1, in <module>
|
||||
slozh(dict1, dict2, dict3, dict4) #Сложение словарей
|
||||
File "<pyshell#23>", line 3, in slozh
|
||||
return a1+a2+a3+a4
|
||||
TypeError: unsupported operand type(s) for +: 'dict' and 'dict'
|
||||
```
|
||||
|
||||
### 2.5. Функция, реализующая модель "Вход х - Выход у"
|
||||
|
||||
```py
|
||||
def inerz(x,T,ypred):
|
||||
""" Модель устройства с памятью:
|
||||
x - текущее значение вх.сигнала,
|
||||
T - постоянная времени,
|
||||
ypred - предыдущее значение выхода устройства"""
|
||||
y=(x+T*ypred)/(T+1)
|
||||
return y
|
||||
|
||||
sps=[0]+[1]*100
|
||||
spsy=[] #Заготовили список для значений выхода
|
||||
TT=20 #Постоянная времени
|
||||
yy=0 #Нулевое начальное условие
|
||||
for xx in sps:
|
||||
yy=inerz(xx,TT,yy)
|
||||
spsy.append(yy)
|
||||
|
||||
plt.xlabel("t, время")
|
||||
plt.ylabel("Выходной синал")
|
||||
plt.grid(True)
|
||||
plt.plot(spsy, label = "Выходной сигнал", color='purple')
|
||||
plt.show()
|
||||
```
|
||||

|
||||
|
||||
## 3. Функции как объекты
|
||||
### 3.1. Получение списка атрибутов объекта-функции
|
||||
|
||||
```py
|
||||
dir(inerz)
|
||||
['__annotations__', '__builtins__', '__call__', '__class__', '__closure__', '__code__', '__defaults__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__get__', '__getattribute__', '__getstate__', '__globals__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__kwdefaults__', '__le__', '__lt__', '__module__', '__name__', '__ne__', '__new__', '__qualname__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__type_params__']
|
||||
inerz.__doc__ # пример использования атрибута функции
|
||||
'Модель устройства с памятью:\nx- текущее значение вх.сигнала,\nT -постоянная времени,\nypred - предыдущее значение выхода устройства'
|
||||
help(inerz)
|
||||
Help on function inerz in module __main__:
|
||||
|
||||
inerz(x, T, ypred) # получаем обработанную документацию
|
||||
Модель устройства с памятью:
|
||||
x- текущее значение вх.сигнала,
|
||||
T -постоянная времени,
|
||||
ypred - предыдущее значение выхода устройства
|
||||
```
|
||||
### 3.2. Сохранение ссылки на объект-функцию в другой переменной
|
||||
```py
|
||||
fnkt=sravnenie # сохраняем ссылку на функцию sravnenie в переменной fnkt
|
||||
v=16fnkt(v,23)
|
||||
16 меньше 23
|
||||
```
|
||||
### 3.3. Альтернативное определение функции в программе
|
||||
|
||||
```py
|
||||
if typ_fun==1:
|
||||
def func():
|
||||
print('Функция 1')
|
||||
else:
|
||||
def func():
|
||||
print('Функция 2')
|
||||
|
||||
func()
|
||||
Функция 2 # так как значение не равно 1, то выполняется else
|
||||
```
|
||||
## 4. Аргументы функции
|
||||
### 4.1. Использование функции в качестве аргумента другой функции
|
||||
```py
|
||||
def fun_arg(fff,a,b,c):
|
||||
"""fff-имя функции, используемой
|
||||
в качестве аргумента функции fun_arg"""
|
||||
return a+fff(c,b)
|
||||
|
||||
zz=fun_arg(logistfun,-3,1,0.7)
|
||||
zz
|
||||
-2.3318122278318336
|
||||
```
|
||||
|
||||
### 4.2. Обязательные и необязательные аргументы
|
||||
|
||||
```py
|
||||
def logistfun(a,b=1): #Аргумент b – необязательный; значение по умолчанию=1
|
||||
"""Вычисление логистической функции"""
|
||||
import math
|
||||
return b/(1+math.exp(-a))
|
||||
|
||||
logistfun(0.7) #Вычисление со значением b по умолчанию
|
||||
0.6681877721681662
|
||||
logistfun(0.7,2) #Вычисление с заданным значением b1.3363755443363323
|
||||
```
|
||||
|
||||
### 4.3. Обращение к функции с произвольным (непозиционным) расположением аргументов
|
||||
|
||||
```py
|
||||
logistfun(b=0.5,a=0.8) # Ссылки на аргументы поменялись местами
|
||||
0.34498724056380625
|
||||
```
|
||||
### 4.4. Пример со значениями аргументов функции, содержащимися в списке или кортеже
|
||||
|
||||
```py
|
||||
b1234=[b1,b2,b3,b4] # Список списков из п.2.4
|
||||
qq=slozh(*b1234) # Перед ссылкой на список или кортеж надо ставить звездочку
|
||||
b1234
|
||||
[[1, 2], [-1, -2], [0, 2], [-1, -1]]
|
||||
qq
|
||||
[1, 2, -1, -2, 0, 2, -1, -1]
|
||||
```
|
||||
|
||||
### 4.5. Значения аргументов функции, содержащиеся в словаре
|
||||
|
||||
```py
|
||||
dic4={"a1":1,"a2":2,"a3":3,"a4":4}
|
||||
qqq=slozh(**dic4) #Перед ссылкой на словарь надо ставить две звездочки
|
||||
```
|
||||
|
||||
### 4.6. Смешанные ссылки
|
||||
|
||||
```py
|
||||
e1=(-1,6);dd2={'a3':3,'a4':9}
|
||||
qqqq=slozh(*e1,**dd2)
|
||||
qqqq
|
||||
17
|
||||
```
|
||||
### 4.7. Переменное число аргументов у функции
|
||||
|
||||
```py
|
||||
def func4(*kort7):
|
||||
"""Произвольное число аргументов в составе кортежа"""
|
||||
smm=0
|
||||
for elt in kort7:
|
||||
smm+=elt
|
||||
return smm
|
||||
func4(-1,2) #Обращение к функции с 2 аргументами
|
||||
1
|
||||
func4(-1,2,0,3,6) #Обращение к функции с 5 аргументами
|
||||
10
|
||||
```
|
||||
### 4.8. Комбинация аргументов
|
||||
|
||||
```py
|
||||
def func4(a,b=7,*kort7): # Аргументы: a-позиционный, b- по умолчанию + кортеж
|
||||
"""Кортеж - сборка аргументов - должен быть последним!"""
|
||||
smm=0
|
||||
for elt in kort7:
|
||||
smm+=elt
|
||||
return a*smm+b
|
||||
func4(-1,2,0,3,6)
|
||||
-7
|
||||
|
||||
def func5(a, b = 7, **slov7): # со словарем
|
||||
"""Словарь - сборка аргументов - должен быть последним!"""
|
||||
smm = 0
|
||||
for elt in slov7.items():
|
||||
smm = sum (slov7.values())
|
||||
return a * smm + b
|
||||
|
||||
numbers = {"a1": 1, "a2": 2, "a3": 3, "a4": 4}
|
||||
func5(1,2,**numbers)
|
||||
12
|
||||
```
|
||||
### 4.9. Изменение значений объектов, используемых в качестве аргументов функции
|
||||
|
||||
```py
|
||||
a=90 # Числовой объект – не изменяемый тип
|
||||
def func3(b):
|
||||
b=5*b+67
|
||||
|
||||
func3(a)
|
||||
a # значение не изменилось
|
||||
90
|
||||
```
|
||||
Пример со списком
|
||||
|
||||
```py
|
||||
sps1=[1,2,3,4] #Список – изменяемый тип объекта
|
||||
def func2(sps):
|
||||
sps[1]=99
|
||||
|
||||
func2(sps1)
|
||||
print(sps1)
|
||||
[1, 99, 3, 4] # список изменился
|
||||
|
||||
kort=(1,2,3,4) #Кортеж – неизменяемый тип объекта
|
||||
func2(kort)
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#104>", line 1, in <module>
|
||||
func2(kort)
|
||||
File "<pyshell#100>", line 2, in func2
|
||||
sps[1]=99
|
||||
TypeError: 'tuple' object does not support item assignment
|
||||
```
|
||||
## 5. Специальные типы пользовательских функций
|
||||
### 5.1. Анонимные функции(лямбда-функции)
|
||||
Функции без имени
|
||||
```py
|
||||
anfun1=lambda: 1.5+math.log10(17.23) #Анонимная функция без аргументов
|
||||
anfun1() # Обращение к объекту-функции
|
||||
2.7362852774480286
|
||||
|
||||
anfun2=lambda a,b: a+math.log10(b) #Анонимная функция с 2 аргументами
|
||||
anfun2(17,234)
|
||||
19.369215857410143
|
||||
|
||||
anfun3=lambda a,b=234: a+math.log10(b) #Функция с необязательным вторым аргументом
|
||||
anfun3(100)
|
||||
102.36921585741014
|
||||
```
|
||||
### 5.2. Функции-генераторы
|
||||
Это – такие функции, которые используются в итерационных процессах, позволяя на каждой
|
||||
итерации получать одно из значений.
|
||||
```py
|
||||
def func5(diap,shag):
|
||||
""" Итератор, возвращающий значения
|
||||
из диапазона от 1 до diap с шагом shag"""
|
||||
for j in range(1,diap+1,shag):
|
||||
yield j # приостанавливает выполнение и возвращает очередное значение
|
||||
|
||||
for mm in func5(7,3):
|
||||
print(mm)
|
||||
1
|
||||
4
|
||||
7
|
||||
```
|
||||
метод __next__, активирует очередную итерацию выполнения функции
|
||||
|
||||
```py
|
||||
alp=func5(7,3)
|
||||
print(alp.__next__())
|
||||
1
|
||||
print(alp.__next__())
|
||||
4
|
||||
print(alp.__next__())
|
||||
7
|
||||
print(alp.__next__())
|
||||
Traceback (most recent call last): # Функция уже выполнила последнюю итерацию, вернулась ошибка
|
||||
File "<pyshell#122>", line 1, in <module>
|
||||
print(alp.__next__())
|
||||
StopIteration
|
||||
```
|
||||
## 6. Локализация объектов в функциях
|
||||
Все объекты могут быть определены глобально или локально. Глобально определены вне функций
|
||||
|
||||
### 6.1. Примеры на локализацию объектов
|
||||
Пример 1 Одноименные локальный и глобальный объекты:
|
||||
```py
|
||||
glb=10
|
||||
def func7(arg):
|
||||
loc1=15
|
||||
glb=8
|
||||
return loc1*arg
|
||||
|
||||
res=func7(glb)
|
||||
res
|
||||
150
|
||||
glb # глобальное значение не изменилось
|
||||
10
|
||||
```
|
||||
Пример 2 Ошибка в использовании локального объекта
|
||||
|
||||
```py
|
||||
def func8(arg):
|
||||
loc1=15
|
||||
print(glb)
|
||||
glb=8
|
||||
return loc1*arg
|
||||
|
||||
res=func8(glb)
|
||||
Traceback (most recent call last): # ошибка происходит так как вывод функции осуществляется в 3 строке функции, а ее объявляение в 4
|
||||
File "<pyshell#131>", line 1, in <module>
|
||||
res=func8(glb)
|
||||
File "<pyshell#130>", line 3, in func8
|
||||
print(glb)
|
||||
UnboundLocalError: cannot access local variable 'glb' where it is not associated with a value
|
||||
```
|
||||
Пример 3 Переопределение локализации объекта
|
||||
```py
|
||||
glb=11
|
||||
def func7(arg):
|
||||
loc1=15
|
||||
global glb
|
||||
print(glb)
|
||||
glb=8
|
||||
return loc1*arg
|
||||
|
||||
res=func7(glb)
|
||||
11
|
||||
glb # значение изменится так как мы обратились к глобальной переменной внутри функции
|
||||
8
|
||||
```
|
||||
### 6.2. Выявление локализации объекта с помощью функций locals() и globals() из builtins
|
||||
|
||||
```py
|
||||
globals().keys() #Перечень глобальных объектов
|
||||
dict_keys(['__name__', '__doc__', '__package__', '__loader__', '__spec__', '__annotations__', '__builtins__', 'os', 'uspeh', 'sravnenie', 'n', 'm', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'dict1', 'dict2', 'dict3', 'dict4', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'fnkt', 'typ_fun', 'func', 'fun_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'func5', 'numbers', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'mm', 'alp', 'glb', 'func7', 'res', 'func8', 'b'])
|
||||
locals().keys() #Перечень локальных объектов
|
||||
dict_keys(['__name__', '__doc__', '__package__', '__loader__', '__spec__', '__annotations__', '__builtins__', 'os', 'uspeh', 'sravnenie', 'n', 'm', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'dict1', 'dict2', 'dict3', 'dict4', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'fnkt', 'typ_fun', 'func', 'fun_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'func5', 'numbers', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'mm', 'alp', 'glb', 'func7', 'res', 'func8', 'b'])
|
||||
```
|
||||
Сейчас они не отличаются, так как эти методы возвращают объекты на уровне вызова этих функций.
|
||||
|
||||
```py
|
||||
hh=func8(glb)
|
||||
dict_keys(['__name__', '__doc__', '__package__', '__loader__', '__spec__', '__annotations__', '__builtins__', 'os', 'uspeh', 'sravnenie', 'n', 'm', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'dict1', 'dict2', 'dict3', 'dict4', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'fnkt', 'typ_fun', 'func', 'fun_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'func5', 'numbers', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'mm', 'alp', 'glb', 'func7', 'res', 'func8', 'b']) # глобальные переменные
|
||||
dict_keys(['arg', 'loc1', 'glb']) # локальные переменные
|
||||
'glb' in globals().keys()
|
||||
True
|
||||
```
|
||||
### 6.3. Локализация объектов при использовании вложенных функций
|
||||
|
||||
```py
|
||||
def func9(arg2,arg3):
|
||||
def func9_1(arg1):
|
||||
loc1=15
|
||||
glb1=8
|
||||
print('glob_func9_1:',globals().keys())
|
||||
print('locl_func9_1:',locals().keys())
|
||||
return loc1*arg1
|
||||
loc1=5
|
||||
glb=func9_1(loc1)
|
||||
print('loc_func9:',locals().keys())
|
||||
print('glob_func9:',globals().keys())
|
||||
return arg2+arg3*glb
|
||||
kk=func9(10,1)
|
||||
|
||||
glob_func9_1: dict_keys(['__name__', '__doc__', '__package__', '__loader__', '__spec__', '__annotations__', '__builtins__', 'os', 'uspeh', 'sravnenie', 'n', 'm', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'dict1', 'dict2', 'dict3', 'dict4', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'fnkt', 'typ_fun', 'func', 'fun_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'func5', 'numbers', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'mm', 'alp', 'glb', 'func7', 'res', 'func8', 'b', 'hh', 'func9'])
|
||||
locl_func9_1: dict_keys(['arg1', 'loc1', 'glb1'])
|
||||
loc_func9: dict_keys(['arg2', 'arg3', 'func9_1', 'loc1', 'glb'])
|
||||
glob_func9: dict_keys(['__name__', '__doc__', '__package__', '__loader__', '__spec__', '__annotations__', '__builtins__', 'os', 'uspeh', 'sravnenie', 'n', 'm', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'dict1', 'dict2', 'dict3', 'dict4', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'fnkt', 'typ_fun', 'func', 'fun_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'func5', 'numbers', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'mm', 'alp', 'glb', 'func7', 'res', 'func8', 'b', 'hh', 'func9'])
|
||||
```
|
||||
|
||||
### 6.4. Моделирование системы
|
||||
|
||||
```py
|
||||
znach=input('k1,T,k2,Xm,A,F,N=').split(',')
|
||||
k1,T,k2,Xm,A,F,N=1, 4, 6, 8, 0.1, 100, 77
|
||||
k1=float(znach[0]) # распаковка каждого значения из списка в отдельную переменную
|
||||
T=float(znach[1])k2=float(znach[2])
|
||||
Xm=float(znach[3])
|
||||
A=float(znach[4])
|
||||
F=float(znach[5])
|
||||
N=int(znach[6])
|
||||
import math
|
||||
vhod=[]
|
||||
for i in range(N): # реализация входного сигнала
|
||||
vhod.append(A*math.sin((2*i*math.pi)/F))
|
||||
|
||||
vhod
|
||||
[0.0, 0.006279051952931338, 0.012533323356430426, 0.01873813145857246, 0.02486898871648548, 0.03090169943749474, 0.03681245526846779, 0.042577929156507266, 0.04817536741017153, 0.05358267949789967, 0.058778525229247314, 0.06374239897486897, 0.06845471059286887, 0.07289686274214116, 0.07705132427757894, 0.08090169943749474, 0.08443279255020152, 0.08763066800438638, 0.09048270524660196, 0.09297764858882514, 0.09510565162951536, 0.09685831611286311, 0.09822872507286887, 0.09921147013144778, 0.09980267284282716, 0.1, 0.09980267284282716, 0.0992114701314478, 0.09822872507286888, 0.09685831611286311, 0.09510565162951537, 0.09297764858882515, 0.09048270524660196, 0.08763066800438635, 0.0844327925502015, 0.08090169943749476, 0.07705132427757894, 0.07289686274214115, 0.06845471059286888, 0.06374239897486898, 0.05877852522924733, 0.0535826794978997, 0.048175367410171525, 0.042577929156507294, 0.03681245526846782, 0.030901699437494753, 0.024868988716485525, 0.01873813145857246, 0.012533323356430454, 0.006279051952931359, 1.2246467991473533e-17, -0.006279051952931335, -0.01253332335643043, -0.018738131458572477, -0.02486898871648546, -0.03090169943749473, -0.03681245526846779, -0.04257792915650723, -0.04817536741017154, -0.053582679497899646, -0.05877852522924727, -0.06374239897486897, -0.06845471059286884, -0.07289686274214116, -0.07705132427757894, -0.08090169943749474, -0.08443279255020153, -0.08763066800438636, -0.09048270524660199, -0.09297764858882515, -0.09510565162951536, -0.09685831611286312, -0.09822872507286888, -0.09921147013144778, -0.09980267284282716, -0.1, -0.09980267284282716]
|
||||
```
|
||||
Функции реализующие компоненты системы
|
||||
|
||||
```py
|
||||
def realdvig(xtt,kk1,TT,yti1,ytin1):
|
||||
#Модель реального двигателя
|
||||
yp=kk1*xtt #усилитель
|
||||
yti1=yp+yti1 #Интегратор
|
||||
ytin1=(yti1+TT*ytin1)/(TT+1)
|
||||
return [yti1,ytin1]
|
||||
|
||||
def tahogen(xtt,kk2,yti2):
|
||||
#Модель тахогенератора
|
||||
yp=kk2*xtt #усилитель
|
||||
yti2=yp+yti2 #интегратор
|
||||
return yti2
|
||||
|
||||
def nechus(xtt,gran):
|
||||
#зона нечувствит
|
||||
if xtt<gran and xtt>(-gran):
|
||||
ytt=0
|
||||
elif xtt>=gran:
|
||||
ytt=xtt-gran
|
||||
elif xtt<=(-gran):
|
||||
ytt=xtt+gran
|
||||
return ytt
|
||||
```
|
||||
Соединение компонент в соответствии с заданием
|
||||
|
||||
```py
|
||||
yi1=0;yin1=0;yi2=0
|
||||
vyhod=[]
|
||||
for xt in vhod:
|
||||
xt1=xt-yi2 #отрицательная обратная связь
|
||||
[yi1,yin1]=realdvig(xt1,k1,T,yi1,yin1)
|
||||
yi2=tahogen(yin1,k2,yi2)
|
||||
yt=nechus(yin1,Xm)
|
||||
vyhod.append(yt)
|
||||
|
||||
print('y=',vyhod)
|
||||
y= [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1.5141467180616637, 2.436597981398414, 0, -23.648551283064812, -14.586132260625703, 32.08584980450739, 89.54211200549014, 25.7748383079563, -159.50156906660678, -269.78397091031354, 10.068957187950126, 609.1466943956274, 710.2274755410508, -432.96310970489685, -2071.215944848495, -1597.6603885543427, 2476.1333543804712, 6477.956582202103, 2626.2544178282487, -10653.374481183546, -18710.49654358021, -114.61846653968969, 39934.80067535607, 49244.49063253727, -25137.392758059512, -136326.86476806158, -113347.77120772432, 152977.09900234317, 430425.27047852875, 200239.35715241256, -676334.6538246117, -1258436.7595393702, -94814.83077922332, 2579157.721342821, 3366440.70542351, -1395363.2125185598, -8922019.998095734, -7954112.681058888, 9354374.734397378, 28510095.7464239, 14931466.339167053, -42752396.61128703, -84417589.66346069, -11966716.801496733, 166137062.55300295, 229398711.23742872, -74491804.49954477, -582713905.5745344, -555144565.8307699, 567231399.1647252, 1884775004.5638165, 1096722694.409165, -2691873575.07944]
|
||||
```
|
||||
## 7. Закончила сеанс работы с IDLE
|
||||
|
||||
@ -0,0 +1,53 @@
|
||||
# Общее контрольное задание по теме 7
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
Разработайте и проверьте функцию, реализующую для момента времени t расчет выхода y(t)
|
||||
для устройства задержки: на вход поступает сигнал, а на выходе повторяется этот сигнал с
|
||||
задержкой на заданное время Т.
|
||||
|
||||
```py
|
||||
def delay(signal, T):
|
||||
""""Расчёт выхода y(t) для устройства задержки
|
||||
signal - входной сигнал
|
||||
T-параметр задержки сигнала"""
|
||||
output=[]
|
||||
for i in range(len(signal)+T):
|
||||
if i < T:
|
||||
output.append(0)
|
||||
else:
|
||||
output.append(signal[i-T])
|
||||
return output
|
||||
|
||||
x = [1, 2, 3, 4, 5, 6]
|
||||
res = delay(x, 6)
|
||||
res
|
||||
[0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 5, 6]
|
||||
```
|
||||
|
||||
Разработайте и проверьте функцию, реализующую расчет гистограммы по выборке случайной
|
||||
величины с каким-то распределением.
|
||||
|
||||
```py
|
||||
def hist(f, x):
|
||||
"""Функция, строящая гистограмму
|
||||
f - выборка
|
||||
x - количество интервалов
|
||||
Возвращает число элементов в каждом интервале"""
|
||||
pylab.hist(f, x)
|
||||
pylab.show()
|
||||
|
||||
f=[random.gauss(0, 1) for _ in range(10)]
|
||||
histogramm(f, 6)
|
||||
```
|
||||

|
||||
|
||||
Разработайте и проверьте анонимную функцию, вычисляющую значение оценки отклика Y
|
||||
линейной регрессии при значении переменной Х
|
||||
Y=b1+b2*X
|
||||
и имеющую аргументы b1, b2 и X.
|
||||
|
||||
```py
|
||||
Y = lambda b1,b2,X: b1+b2*X
|
||||
Y(1, 2, 3)
|
||||
7
|
||||
```
|
||||
@ -0,0 +1,50 @@
|
||||
# Индивидуальное контрольное задание вариант 18
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
Разработайте функцию с двумя аргументами: имя некоторого объекта-последовательности и имя текстового файла вывода.
|
||||
Функция должна осуществлять запись указанного объекта в заданный файл вывода, причем если объект – это символьная строка, то его надо записать в файл на одной строке, если объект – список или кортеж, то каждый элемент должен записываться на одной строке файла.
|
||||
|
||||
```py
|
||||
def func(obj, file):
|
||||
""" Запись объекта-последовательности в текстовый файл
|
||||
obj - имя объекта
|
||||
file - имя файла для записи"""
|
||||
with open(file, 'w', encoding='utf-8') as fp:
|
||||
if type(obj)==str:
|
||||
fp.write(obj)
|
||||
elif type(obj)==list:
|
||||
for i in obj:
|
||||
fp.write(str(i)+'\n')
|
||||
elif type(obj)==tuple:
|
||||
for i in obj:
|
||||
fp.write(str(i)+'\n')
|
||||
else:
|
||||
print('Неверный тип')
|
||||
```
|
||||
|
||||
Проверить функцию с объектами разных классов.
|
||||
|
||||
```py
|
||||
func([1, 'Hi', 3.33], "file2.txt") # Проверка для списка
|
||||
func('пум пум пум пурум', "file5.txt") # Проверка для строки
|
||||
func(('банан', 'пум пум', 'ноль'), "file3.txt") # Проверка для кортежа
|
||||
```
|
||||
Содержимое файла file2.txt
|
||||
|
||||
```py
|
||||
1
|
||||
Hi
|
||||
3.33
|
||||
```
|
||||
|
||||
Содержимое файла file5.txt
|
||||
```py
|
||||
пум пум пум пурум
|
||||
```
|
||||
|
||||
Содержимое файла file3.txt
|
||||
```py
|
||||
банан
|
||||
пум пум
|
||||
ноль
|
||||
```
|
||||
@ -0,0 +1,2 @@
|
||||
import MM2
|
||||
print("y =", MM2.vyhod)
|
||||
@ -0,0 +1,21 @@
|
||||
def realdvig(xtt, kk1, TT, yti1, ytin1):
|
||||
# Модель реального двигателя
|
||||
yp = kk1 \* xtt # Усилитель
|
||||
yti1 = yp + yti1 # Усилитель
|
||||
ytin1 = (yti1 + TT \* ytin1) / (TT + 1)
|
||||
return \[yti1, ytin1]
|
||||
|
||||
def tahogen(xtt, kk2, yti2):
|
||||
# Модель тахогенератора
|
||||
yp = kk2 * xtt # Усилитель
|
||||
yti2 = yp + yti2 # Интегратор
|
||||
return yti2
|
||||
|
||||
def nechus(xtt, gran):
|
||||
# Зона нечувствительности
|
||||
if xtt < gran and xtt > (-gran):
|
||||
return 0
|
||||
elif xtt >= gran:
|
||||
return xtt - gran
|
||||
elif xtt <= (-gran):
|
||||
return xtt + gran
|
||||
@ -0,0 +1,21 @@
|
||||
znach = input("k1, T, k2, Xm, A, F, N = ").split(",")
|
||||
k1 = float(znach[0])
|
||||
T = float(znach[1])
|
||||
k2 = float(znach[2])
|
||||
Xm = float(znach[3])
|
||||
A = float(znach[4])
|
||||
F = float(znach[5])
|
||||
N = int(znach[6])
|
||||
import math
|
||||
vhod = []
|
||||
for i in range(N):
|
||||
vhod.append(A * math.sin((2 * i * math.pi) / F))
|
||||
import MM1 as mod
|
||||
yi1 = 0; yin1 = 0; yi2 = 0
|
||||
vyhod = []
|
||||
for xt in vhod:
|
||||
xt1 = xt - yi2
|
||||
[yi1, yin1] = mod.realdvig(xt1, k1, T, yi1, yin1)
|
||||
yi2 = mod.tahogen(yin1, k2, yi2)
|
||||
yt = mod.nechus(yin1, Xm)
|
||||
vyhod.append(yt)
|
||||
@ -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
|
||||
@ -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
|
||||
@ -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))
|
||||
@ -0,0 +1,363 @@
|
||||
# Отчет по теме 8
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
# Модули и структурирование программы
|
||||
## 1. Установка рабочего каталога
|
||||
|
||||
```py
|
||||
import importlib
|
||||
import os,sys
|
||||
os.getcwd() #Контролируем корректность установки текущего каталога
|
||||
'H:\\study\\ПОАС'
|
||||
```
|
||||
## 2. Создание и использование модулей в среде Python
|
||||
Модулем в среде Python называется любая часть программного кода на этом языке, записанная в
|
||||
отдельном файле
|
||||
|
||||
### 2.1. Запуск модуля на выполнение путем его импорта
|
||||
Создала файл Mod1.py с содержимым:
|
||||
```py
|
||||
perm1=input('Mod1:Введите значение = ')
|
||||
print('Mod1:Значение perm1=',perm1)
|
||||
```
|
||||
Запустила модуль Mod1.py
|
||||
```py
|
||||
import Mod1
|
||||
Mod1:Введите значение = 3
|
||||
Mod1:Значение perm1= 3
|
||||
|
||||
type(Mod1)
|
||||
<class 'module'>
|
||||
dir(Mod1)
|
||||
['__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'perm1']
|
||||
Mod1.perm1 # Обращение к переменной perm из модуля Mod1
|
||||
'3'
|
||||
```
|
||||
При повторном вызове через import ничего не происходит
|
||||
|
||||
```py
|
||||
import Mod1
|
||||
importlib.reload(Mod1) # для повторного вызова модуля используем reload
|
||||
Mod1:Введите значение = 5
|
||||
Mod1:Значение perm1= 5
|
||||
<module 'Mod1' from 'H:\\study\\ПОАС\\Mod1.py'>
|
||||
Mod1.perm1
|
||||
'5'
|
||||
```
|
||||
### 2.2. Вывод импортированных модулей
|
||||
Импортированные модули заносятся в словарь - значение атрибута sys.modules, поэтому их можно увидеть с помощью инструкции keys().
|
||||
```py
|
||||
print(sorted(sys.modules.keys()))
|
||||
['Mod1', '__future__', '__main__', '_abc', '_ast', '_bisect', '_bz2', '_codecs', '_collections', '_collections_abc', '_colorize', '_compat_pickle', '_compression', '_datetime', '_frozen_importlib', '_frozen_importlib_external', '_functools', '_heapq', '_imp', '_io', '_lzma', '_opcode', '_opcode_metadata', '_operator', '_pickle', '_pyrepl', '_pyrepl.pager', '_queue', '_random', '_signal', '_sitebuiltins', '_socket', '_sre', '_stat', '_string', '_struct', '_suggestions', '_sysconfig', '_thread', '_tkinter', '_tokenize', '_typing', '_warnings', '_weakref', '_weakrefset', '_winapi', '_wmi', 'abc', 'ast', 'bdb', 'binascii', 'bisect', 'builtins', 'bz2', 'codecs', 'collections', 'collections.abc', 'configparser', 'contextlib', 'copyreg', 'datetime', 'dis', 'encodings', 'encodings.aliases', 'encodings.cp1251', 'encodings.utf_8', 'enum', 'errno', 'fnmatch', 'functools', 'genericpath', 'heapq', 'idlelib', 'idlelib.autocomplete', 'idlelib.autocomplete_w', 'idlelib.calltip', 'idlelib.calltip_w', 'idlelib.config', 'idlelib.debugger', 'idlelib.debugger_r', 'idlelib.debugobj', 'idlelib.debugobj_r', 'idlelib.hyperparser', 'idlelib.iomenu', 'idlelib.macosx', 'idlelib.multicall', 'idlelib.pyparse', 'idlelib.rpc', 'idlelib.run', 'idlelib.scrolledlist', 'idlelib.stackviewer', 'idlelib.tooltip', 'idlelib.tree', 'idlelib.util', 'idlelib.window', 'idlelib.zoomheight', 'importlib', 'importlib._abc', 'importlib._bootstrap', 'importlib._bootstrap_external', 'importlib.machinery', 'importlib.util', 'inspect', 'io', 'ipaddress', 'itertools', 'keyword', 'linecache', 'lzma', 'marshal', 'math', 'nt', 'ntpath', 'opcode', 'operator', 'os', 'os.path', 'pickle', 'pkgutil', 'platform', 'plistlib', 'posixpath', 'pydoc', 'pyexpat', 'pyexpat.errors', 'pyexpat.model', 'queue', 'random', 're', 're._casefix', 're._compiler', 're._constants', 're._parser', 'reprlib', 'select', 'selectors', 'shlex', 'shutil', 'site', 'socket', 'socketserver', 'stat', 'string', 'struct', 'sys', 'sysconfig', 'tempfile', 'textwrap', 'threading', 'time', 'tkinter', 'tkinter.constants', 'token', 'tokenize', 'traceback', 'types', 'typing', 'urllib', 'urllib.parse', 'warnings', 'weakref', 'winreg', 'xml', 'xml.parsers', 'xml.parsers.expat', 'xml.parsers.expat.errors', 'xml.parsers.expat.model', 'zipimport', 'zlib']
|
||||
```
|
||||
Для повторного импорта удалим его из словаря.
|
||||
|
||||
```py
|
||||
print(sorted(sys.modules.keys()))
|
||||
['__future__', '__main__', '_abc', '_ast', '_bisect', '_bz2', '_codecs', '_collections', '_collections_abc', '_colorize', '_compat_pickle', '_compression', '_datetime', '_frozen_importlib',...]
|
||||
import Mod1 # еще раз импортировали модуль
|
||||
Mod1:Введите значение = 4
|
||||
Mod1:Значение perm1= 4
|
||||
sys.modules.pop('Mod1') # еще раз удалили модуль
|
||||
<module 'Mod1' from 'H:\\study\\ПОАС\\Mod1.py'>
|
||||
```
|
||||
### 2.3. Запуск модуля на выполнение с помощью функции exec()
|
||||
Для запуска через exec() не трубуется импортировать модуль, но модуль при этом не создается, все созданные при выполнении модуля объекты становятся объектами главной программы
|
||||
```py
|
||||
exec(open('Mod1.py').read())
|
||||
Mod1:Введите значение = 11111
|
||||
Mod1:Значение perm1= 11111
|
||||
exec(open("Mod1.py", encoding = "utf-8").read()) # изменили кодировку
|
||||
Mod1:Введите значение = 11111111
|
||||
Mod1:Значение perm1= 11111111
|
||||
perm1
|
||||
'11111111'
|
||||
exec(open("Mod1.py", encoding = "utf-8").read())
|
||||
Mod1:Введите значение = 777
|
||||
Mod1:Значение perm1= 777
|
||||
perm1
|
||||
'777'
|
||||
```
|
||||
### 2.4. Использование инструкции from … import …
|
||||
В одном модуле может содержаться несколько программных единиц (функций, объектов).
|
||||
Можно осуществить частичный импорт объектов
|
||||
|
||||
```py
|
||||
'777'
|
||||
from Mod1 import perm1
|
||||
Mod1:Введите значение = 1111
|
||||
Mod1:Значение perm1= 1111
|
||||
dir()
|
||||
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', '__warningregistry__', 'importlib', 'os', 'perm1', 'sys']
|
||||
"Mod1" in dir() # Модуль Mod1 не появился в памяти
|
||||
False
|
||||
perm1 # переменная модуля стала переменной программы
|
||||
'1111'
|
||||
```
|
||||
Создала второй модуль Mod2:
|
||||
|
||||
```py
|
||||
def alpha():
|
||||
print('****ALPHA****')
|
||||
t=input('Значение t=')
|
||||
return t
|
||||
def beta(q):
|
||||
import math
|
||||
expi=q*math.pi
|
||||
return math.exp(expi)
|
||||
```
|
||||
Импортировали только функцию beta
|
||||
|
||||
```py
|
||||
from Mod2 import beta
|
||||
g=beta(2)
|
||||
g
|
||||
535.4916555247646
|
||||
"Mod2" in dir()
|
||||
False
|
||||
alpha() # Функция alpha не была импортировна, поэтому к ней нельзя обращаться
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#205>", line 1, in <module>
|
||||
alpha() # Функция alpha не была импортировна, поэтому к ней нельзя обращаться
|
||||
NameError: name 'alpha' is not defined
|
||||
```
|
||||
Импортируем alpha из Mod2
|
||||
|
||||
```py
|
||||
from Mod2 import alpha as al # присвоили имя al
|
||||
al()
|
||||
****ALPHA****
|
||||
Значение t=5
|
||||
'5'
|
||||
from Mod2 import alpha as al, beta as bt # можем импортировать обе функции
|
||||
dir()
|
||||
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'al', 'bt', 'g', 'importlib', 'os', 'perm1', 'sys']
|
||||
del al,beta # удалили импортированные объекты
|
||||
from Mod2 import * # импорт всего содержимого
|
||||
tt=alpha() #На запрос введите значение 0.12
|
||||
****ALPHA****
|
||||
Значение t=0.12
|
||||
uu=beta(float(tt))uu
|
||||
1.4578913609506803
|
||||
```
|
||||
## 3.Создание многомодульных программ
|
||||
### 3.1. Пример простой многомодульной программы
|
||||
|
||||
Создали Mod0:
|
||||
```py
|
||||
#Модуль Mod0
|
||||
import Mod1
|
||||
print('perm1=',Mod1.perm1)
|
||||
from Mod2 import alpha as al
|
||||
tt=al()
|
||||
print('tt=',tt)
|
||||
from Mod2 import beta
|
||||
qq=beta(float(tt))
|
||||
print('qq=',qq)
|
||||
```
|
||||
Программа состоит из нескольких модулей
|
||||
|
||||
```py
|
||||
sys.modules.pop("Mod1") # удалили лишние модули
|
||||
<module 'Mod1' from 'H:\\study\\ПОАС\\Mod1.py'>
|
||||
sys.modules.pop("Mod2")
|
||||
<module 'Mod2' from 'H:\\study\\ПОАС\\Mod2.py'>
|
||||
|
||||
import Mod0
|
||||
Mod1:Введите значение = 111
|
||||
Mod1:Значение perm1= 111
|
||||
perm1= 111
|
||||
****ALPHA****
|
||||
Значение t=77
|
||||
tt= 77
|
||||
qq= 1.1401952983082614e+105
|
||||
|
||||
Mod0.tt; Mod0.qq; Mod0.Mod1.perm1
|
||||
'77'
|
||||
1.1401952983082614e+105
|
||||
'111'
|
||||
```
|
||||
### 3.2. Создание многомодульной программы на примере функций из Темы 7
|
||||
|
||||
Создала модуль MM1.py в который записала модель системы из темы 7
|
||||
```py
|
||||
def realdvig(xtt, kk1, TT, yti1, ytin1):
|
||||
# Модель реального двигателя
|
||||
yp = kk1 \* xtt # Усилитель
|
||||
yti1 = yp + yti1 # Усилитель
|
||||
ytin1 = (yti1 + TT \* ytin1) / (TT + 1)
|
||||
return \[yti1, ytin1]
|
||||
|
||||
def tahogen(xtt, kk2, yti2):
|
||||
# Модель тахогенератора
|
||||
yp = kk2 * xtt # Усилитель
|
||||
yti2 = yp + yti2 # Интегратор
|
||||
return yti2
|
||||
|
||||
def nechus(xtt, gran):
|
||||
# Зона нечувствительности
|
||||
if xtt < gran and xtt > (-gran):
|
||||
return 0
|
||||
elif xtt >= gran:
|
||||
return xtt - gran
|
||||
elif xtt <= (-gran):
|
||||
return xtt + gran
|
||||
```
|
||||
|
||||
Ввод параметров сохранила в модуль MM2.py
|
||||
|
||||
```py
|
||||
znach = input("k1, T, k2, Xm, A, F, N = ").split(",")
|
||||
k1 = float(znach[0])
|
||||
T = float(znach[1])
|
||||
k2 = float(znach[2])
|
||||
Xm = float(znach[3])
|
||||
A = float(znach[4])
|
||||
F = float(znach[5])
|
||||
N = int(znach[6])
|
||||
import math
|
||||
vhod = []
|
||||
for i in range(N):
|
||||
vhod.append(A * math.sin((2 * i * math.pi) / F))
|
||||
import MM1 as mod
|
||||
yi1 = 0; yin1 = 0; yi2 = 0
|
||||
vyhod = []
|
||||
for xt in vhod:
|
||||
xt1 = xt - yi2
|
||||
[yi1, yin1] = mod.realdvig(xt1, k1, T, yi1, yin1)
|
||||
yi2 = mod.tahogen(yin1, k2, yi2)
|
||||
yt = mod.nechus(yin1, Xm)
|
||||
vyhod.append(yt)
|
||||
```
|
||||
Программа запускающая остальные модули MM0.py
|
||||
```py
|
||||
import MM2
|
||||
print("y =", MM2.vyhod)
|
||||
```
|
||||
Запуск многомодульной программы
|
||||
```py
|
||||
import MM0
|
||||
k1, T, k2, Xm, A, F, N = 8, 5, 3, 5, 3, 50, 20
|
||||
y = [0, 0, 0, 0, 0, 0, -0.5901518991576866, 3.452634704774537, 0.3642909010247486, -28.2151620053697, 26.675026712827304, 51.21473287127543, -172.66693667770392, 78.76799406127618, 417.8318242176528, -859.8658159198188, -43.91966881153879, 2710.4996464065, -3753.6472426408995, -2892.354195893288]
|
||||
```
|
||||
### 3.3. Области действия объектов в модулях
|
||||
Обратимся из одной функции к другой в модуле Mod2.py
|
||||
Вставим в функцию alpha обращение к функции beta и, наоборот, из beta – к alpha.
|
||||
```py
|
||||
def alpha():
|
||||
print("****ALPHA****")
|
||||
print("Вызов функции beta из функции alpha:", beta(0))
|
||||
t = input("Значение t = ")
|
||||
return t
|
||||
```
|
||||
Запуск модуля
|
||||
```py
|
||||
import Mod2
|
||||
Mod2.alpha()
|
||||
****ALPHA****
|
||||
Вызов функции beta из функции alpha: 1.0
|
||||
Значение t = 202020
|
||||
'202020'
|
||||
```
|
||||
Для функции beta в модуле Mod2.py
|
||||
```py
|
||||
def beta(q):
|
||||
print("****BETA****")
|
||||
print("Вызов функции alpha из функции beta:", alpha())
|
||||
import math
|
||||
expi = q * math.pi
|
||||
return math.exp(expi)
|
||||
```
|
||||
Запустим модуль
|
||||
```py
|
||||
import Mod2
|
||||
Mod2.beta(4)
|
||||
****BETA****
|
||||
****ALPHA****
|
||||
Значение t = 5
|
||||
Вызов функции alpha из функции beta: 5
|
||||
286751.31313665316
|
||||
```
|
||||
Отобразим на экране в модуле Mod0 значения объектов t и expi
|
||||
Модуль Mod1
|
||||
```py
|
||||
import Mod1
|
||||
print("perm1 =", Mod1.perm1)
|
||||
from Mod2 import alpha as al
|
||||
tt = al()
|
||||
print("tt =", tt)
|
||||
from Mod2 import beta
|
||||
qq = beta(float(tt))
|
||||
print("qq =", qq)
|
||||
print("t =", t)
|
||||
print("expi =", expi)
|
||||
```
|
||||
```py
|
||||
import Mod0
|
||||
Mod1: Введите значение = 1
|
||||
Mod1: Значение perm1 = 1
|
||||
perm1 = 1
|
||||
****ALPHA****
|
||||
Значение t = 2
|
||||
tt = 2
|
||||
****BETA****
|
||||
qq = 535.4916555247646
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#252>", line 1, in <module>
|
||||
import Mod0
|
||||
File "H:\\study\\ПОАС\\Mod0.py"
|
||||
print("t =", t, " expi =", expi)
|
||||
NameError: name 't' is not defined. Did you mean: 'tt'?
|
||||
```
|
||||
При обращении к переменной t, будет ошибка, так как переменная определена в другом модуле и к ней нельзя обратиться напрямую
|
||||
аналогично с переменной expi
|
||||
|
||||
Попробуем в модуле Mod0 увеличить в 3 раза значение объекта perm1 и отобразить его после
|
||||
этого на экране.
|
||||
|
||||
```py
|
||||
import Mod1
|
||||
print("perm1 =", Mod1.perm1)
|
||||
from Mod2 import alpha as al
|
||||
tt = al()
|
||||
print("tt =", tt)
|
||||
from Mod2 import beta
|
||||
qq = beta(float(tt))
|
||||
print("qq =", qq)
|
||||
Mod1.perm1 *= 3
|
||||
print("perm1 * 3 =", Mod1.perm1)
|
||||
```
|
||||
Запустим
|
||||
```py
|
||||
import Mod0
|
||||
Mod1: Введите значение = 1
|
||||
Mod1: Значение perm1 = 1
|
||||
perm1 = 1
|
||||
****ALPHA****
|
||||
Значение t = 2
|
||||
tt = 2
|
||||
****BETA****
|
||||
qq = 535.4916555247646
|
||||
perm1 * 3 = 111
|
||||
```
|
||||
Попробуем в командной строке (в главном модуле) увеличить в 2 раза значения объектов
|
||||
perm1, tt, qq.
|
||||
```py
|
||||
perm1 *= 2
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#254>", line 1, in <module>
|
||||
perm1 *= 2
|
||||
NameError: name 'perm1' is not defined
|
||||
tt *= 2
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#255>", line 1, in <module>
|
||||
tt *= 2
|
||||
```
|
||||
Аналогично
|
||||
|
||||
Эти переменные локальные для модулей и обращение к ним из командной строке выводит ошибку.
|
||||
|
||||
## 4. Завершила работу со средой
|
||||
|
||||
|
||||
|
||||
@ -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
|
||||
```
|
||||
@ -0,0 +1,48 @@
|
||||
# Индивидуальное контрольное задание вариант 18
|
||||
|
||||
Разработайте функцию с двумя аргументами: имя некоторого объекта-последовательности и имя текстового файла вывода.
|
||||
Функция должна осуществлять запись указанного объекта в заданный файл вывода, причем если объект – это символьная строка, то его надо записать в файл на одной строке, если объект – список или кортеж, то каждый элемент должен записываться на одной строке файла.
|
||||
|
||||
Разработайте функцию, на ее основе создайте модуль.
|
||||
Создайте второй модуль, в котором должны быть инструкции для ввода/создания исходных данных для проверки работы функции, вызов функции и отображение полученных результатов.
|
||||
|
||||
module1.py
|
||||
```py
|
||||
def func(obj, file):
|
||||
""" Запись объекта-последовательности в текстовый файл
|
||||
obj - имя объекта
|
||||
file - имя файла для записи"""
|
||||
with open(file, 'w', encoding='utf-8') as fp:
|
||||
if type(obj)==str:
|
||||
fp.write(obj)
|
||||
elif type(obj)==list:
|
||||
for i in obj:
|
||||
fp.write(str(i)+'\n')
|
||||
elif type(obj)==tuple:
|
||||
for i in obj:
|
||||
fp.write(str(i)+'\n')
|
||||
else:
|
||||
print('Неверный тип')
|
||||
```
|
||||
module2.py
|
||||
|
||||
```py
|
||||
import module1
|
||||
|
||||
obj = input("Введите список/строку/кортеж: ")
|
||||
name = input("Введите имя файла для записи: ")
|
||||
module1.func(obj, name)
|
||||
```
|
||||
Запустим из консоли программу
|
||||
|
||||
```py
|
||||
import module2
|
||||
Введите список/строку/кортеж: '12456'
|
||||
Введите имя файла для записи: sps.txt
|
||||
```
|
||||
|
||||
Содержимое файла sps.txt
|
||||
|
||||
```py
|
||||
12456
|
||||
```
|
||||
|
После Ширина: | Высота: | Размер: 53 KiB |
|
После Ширина: | Высота: | Размер: 42 KiB |
|
После Ширина: | Высота: | Размер: 57 KiB |
@ -0,0 +1,289 @@
|
||||
# Отчет по теме 9
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
## Создание пользовательских классов и объектов
|
||||
|
||||
### 2. Создание классов и их наследников
|
||||
#### 2.1. Создание автономного класса
|
||||
|
||||
```py
|
||||
|
||||
class Class1: # Объявление класса
|
||||
def zad_zn(self, znach): # Метод класса для задания значения поля data
|
||||
self.data = znach # self - ссылка на экземпляр класса Class1
|
||||
def otobrazh(self): # Метод класса для отображения значения поля data
|
||||
print(self.data)
|
||||
|
||||
z1 = Class1() # Создание 1-го экземпляра класса
|
||||
z2 = Class1() # Создание 2-го экземпляра класса
|
||||
z1.zad_zn("Экземпляр класса 1")
|
||||
z2.zad_zn(-632.453)
|
||||
z1.otobrazh()
|
||||
Экземпляр класса 1
|
||||
z2.otobrazh()
|
||||
-632.453
|
||||
z1.data = "Новое значение атрибута у экземпляра 1"
|
||||
z1.otobrazh()
|
||||
Новое значение атрибута у экземпляра 1
|
||||
```
|
||||
|
||||
#### 2.2. Создание класса наследника
|
||||
В объявлении класса после его имени в скобках перечисляются его «родительские классы»
|
||||
```py
|
||||
class Class2(Class1): # Объявление класса-наследника другого класса
|
||||
def otobrazh(self): # Переопределение метода класса-родителя
|
||||
print("Значение =", self.data)
|
||||
|
||||
z3 = Class2()
|
||||
dir(z3)
|
||||
['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'otobrazh', 'zad_zn']
|
||||
z3.zad_zn("Совсем новое")
|
||||
z3.otobrazh() # Сработал переопределенный метод otobrazh класса Class2
|
||||
Значение = Совсем новое
|
||||
z1.otobrazh() # Значение поля data класса Class1 не изменилось
|
||||
Новое значение атрибута у экземпляра 1
|
||||
del z1, z2, z3
|
||||
```
|
||||
### 3.Использование классов, содержащихся в модулях
|
||||
Создала модуль Mod3 с содержанием:
|
||||
|
||||
```py
|
||||
class Class1:
|
||||
def zad_zn(self, znach):
|
||||
self.data = znach
|
||||
def otobrazh(self):
|
||||
print(self.data)
|
||||
|
||||
class Class2(Class1):
|
||||
def otobrazh(self):
|
||||
print("Значение =", self.data)
|
||||
|
||||
def otobrazh(obj):
|
||||
print("Значение объекта =", obj)
|
||||
```
|
||||
Импортируем первый класс из модуля:
|
||||
|
||||
```py
|
||||
from Mod3 import Class1
|
||||
z4 = Class1()
|
||||
z4.otobrazh() # Поле data класса не было инициализировано, поэтому его еще нет в классе
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#29>", line 1, in <module>
|
||||
z4.otobrazh()
|
||||
File "H:\study\ПОАС\Mod3.py", line 5, in otobrazh
|
||||
print(self.data)
|
||||
AttributeError: 'Class1' object has no attribute 'data'
|
||||
z4.data = "Значение поля data у экземпляра 4" # Прямая инициализация поля data
|
||||
z4.otobrazh() # Использован метод для отображения значения поля, описанный в Class1
|
||||
Значение поля data у экземпляра 4
|
||||
del z4
|
||||
```
|
||||
Импортируем полностью модуль
|
||||
```py
|
||||
from Mod3 import Class1
|
||||
z4=Class1()
|
||||
z4.data='значение данного data у экз.4'
|
||||
z4.otobrazh()
|
||||
значение данного data у экз.4
|
||||
del z4
|
||||
```
|
||||
|
||||
### 4. Использование специальных методов
|
||||
Имена специальных методов предваряются одним или двумя подчерками и имеют вид: <имя
|
||||
специального метода>
|
||||
|
||||
```py
|
||||
class Class3(Class2):
|
||||
def __init__(self, znach): # Специальный метод-конструктор
|
||||
self.data = znach
|
||||
def __add__(self, another_zn): # Специальный метод для сложения
|
||||
return Class3(self.data + another_zn)
|
||||
def zad_another_zn(self, povtor): # Обычный пользовательский метод
|
||||
self.data *= povtor
|
||||
|
||||
z5 = Class3("abc")
|
||||
z5.otobrazh()
|
||||
Значение = abc
|
||||
z6 = z5 + "def"
|
||||
z6.otobrazh()
|
||||
Значение = abcdef
|
||||
z6.zad_another_zn(3)
|
||||
z6.otobrazh()
|
||||
Значение = abcdefabcdefabcdef
|
||||
```
|
||||
|
||||
### 5. Присоединение атрибутов к классу
|
||||
```py
|
||||
dir(Class3)
|
||||
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'otobrazh', 'zad_another_zn', 'zad_zn']
|
||||
Class3.fio='Иванов И.И.'
|
||||
z7=Class3(123)
|
||||
dir(Class3)
|
||||
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'fio', 'otobrazh', 'zad_another_zn', 'zad_zn']
|
||||
z7 = Class3(123)
|
||||
dir(z7) # Отображение списка атрибутов объекта класса после добавления в него поля fio
|
||||
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'data', 'fio', 'otobrazh', 'zad_another_zn', 'zad_zn']
|
||||
dir(z7) == dir(Class3)
|
||||
False
|
||||
z7.fio
|
||||
'Иванов И.И.'
|
||||
Class3.fio
|
||||
'Иванов И.И.'
|
||||
z7.rozden = "1987"
|
||||
dir(z7)
|
||||
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'data', 'fio', 'otobrazh', 'rozden', 'zad_another_zn', 'zad_zn']
|
||||
dir(Class3)
|
||||
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'fio', 'otobrazh', 'zad_another_zn', 'zad_zn']
|
||||
"rozden" in dir(z7) # проверим что поле rozden появилось в объекте класса
|
||||
True
|
||||
"rozden" in dir(Class3) # поле rozden не появилось в самом классе
|
||||
False
|
||||
```
|
||||
|
||||
### 6. Выявление родительских классов
|
||||
Такое выявление делается с помощью специального атрибута __bases__
|
||||
```py
|
||||
Class3.__bases__
|
||||
(<class '__main__.Class2'>,)
|
||||
Class2.__bases__
|
||||
(<class '__main__.Class1'>,)
|
||||
Class1.__bases__
|
||||
(<class 'object'>,)
|
||||
```
|
||||
Для получения всей цепочки наследования используем атрибут __mro__:
|
||||
|
||||
```py
|
||||
Class3.__mro__
|
||||
(<class '__main__.Class3'>, <class '__main__.Class2'>, <class '__main__.Class1'>, <class 'object'>)
|
||||
ZeroDivisionError.__mro__
|
||||
(<class 'ZeroDivisionError'>, <class 'ArithmeticError'>, <class 'Exception'>, <class 'BaseException'>, <class 'object'>)
|
||||
```
|
||||
|
||||
### 7. Создание свойств класса
|
||||
Свойство (property) класса – это особый атрибут класса, с которым можно производить операции
|
||||
чтения или задания его значения, а также удаление значения этого атрибута.
|
||||
```py
|
||||
class Class4:
|
||||
def __init__ (self, znach):
|
||||
self.__prm = znach
|
||||
def chten(self):
|
||||
return self.__prm
|
||||
def zapis(self, znch):
|
||||
self.__prm = znch
|
||||
def stiran(self):
|
||||
del self.__prm
|
||||
svojstvo = property(chten, zapis, stiran)
|
||||
|
||||
exempl=Class4(12)
|
||||
exempl.svojstvo
|
||||
12
|
||||
exempl.svojstvo = 45
|
||||
print(exempl.svojstvo)
|
||||
45
|
||||
del exempl.svojstvo
|
||||
exempl.svojstvo # Отображения отсутсвующего в объекте класса свойства вызывает ошибку
|
||||
File "<pyshell#54>", line 5, in chten
|
||||
return self.__prm
|
||||
AttributeError: 'Class4' object has no attribute '_Class4__prm'
|
||||
```
|
||||
### 8. Представление некоторой модели в виде класса
|
||||
модель системы автоматического регулирования (САР), состоящей из последовательного соединения усилителя и двух
|
||||
инерционных звеньев, охваченных отрицательной обратной связью с усилителем.
|
||||
|
||||
Создали модуль SAU.py
|
||||
```py
|
||||
class SAU:
|
||||
def __init__ (self, zn_param):
|
||||
self.param = zn_param
|
||||
self.ypr = [0, 0]
|
||||
|
||||
def zdn_zn(self, upr):
|
||||
self.x = upr
|
||||
|
||||
def model(self):
|
||||
def inerz(x, T, yy):
|
||||
return (x + T * yy) / (T + 1)
|
||||
|
||||
y0 = self.x - self.ypr[1] * self.param[3] # Обратная связь с усилителем 2
|
||||
y1 = self.param[0] * y0 # Усилитель 1
|
||||
y2 = inerz(y1, self.param[1], self.ypr[0]) # Инерционное звено 1
|
||||
y3 = inerz(y2, self.param[2], self.ypr[1]) # Инерционное звено 2
|
||||
self.ypr[0] = y2
|
||||
self.ypr[1] = y3
|
||||
|
||||
def otobrazh(self):
|
||||
print("y =", self.ypr[1])
|
||||
```
|
||||
```py
|
||||
from SAU import *
|
||||
prm = [2.5, 4, 1.3, 0.8] # Параметры модели: K1, T1, T2, K2
|
||||
xx = [0] + [1] * 20 # Входной сигнал – «ступенька»
|
||||
SAUe = SAU(prm)
|
||||
yt = []
|
||||
|
||||
for xt in xx:
|
||||
SAUe.zdn_zn(xt)
|
||||
SAUe.model()
|
||||
SAUe.otobrazh()
|
||||
yt.append(SAUe.ypr[1])
|
||||
|
||||
import pylab
|
||||
pylab.plot(yt)
|
||||
pylab.title("График выходного сигнала")
|
||||
pylab.xlabel("Время - t")
|
||||
pylab.ylabel("Выходной сигнал - y(t)")
|
||||
pylab.grid(True)
|
||||
pylab.show()
|
||||
```
|
||||
Результат работы программы
|
||||
```py
|
||||
import main_SAU
|
||||
y = 0.0
|
||||
y = 0.2173913043478261
|
||||
y = 0.4763705103969754
|
||||
y = 0.686594887811293
|
||||
y = 0.8199324616478645
|
||||
y = 0.8837201137353929
|
||||
y = 0.8994188484874774
|
||||
y = 0.8892777072047301
|
||||
y = 0.870097963179993
|
||||
y = 0.8518346102696789
|
||||
y = 0.8387499784485772
|
||||
y = 0.8314204114211459
|
||||
y = 0.8286051955249649
|
||||
y = 0.8285656555914835
|
||||
y = 0.8297915186846528
|
||||
y = 0.8312697736438287
|
||||
y = 0.8324765218921963
|
||||
y = 0.8332456979978418
|
||||
y = 0.8336163607592184
|
||||
y = 0.8337101315489143
|
||||
y = 0.833654237067147
|
||||
```
|
||||

|
||||
При других значениях параметров
|
||||
prm = [5, 2, 3, 2]
|
||||
```py
|
||||
y = 0.0
|
||||
y = 0.4166666666666667
|
||||
y = 0.6597222222222223
|
||||
y = 0.5931712962962963
|
||||
y = 0.43282214506172834
|
||||
y = 0.3725606031378601
|
||||
y = 0.41758261263288754
|
||||
y = 0.47397622246692106
|
||||
y = 0.48436149012259344
|
||||
y = 0.462222758004719
|
||||
y = 0.44411586377478934
|
||||
y = 0.4446228748662676
|
||||
y = 0.4539720784512614
|
||||
y = 0.4591722749967687
|
||||
y = 0.45753112118915107
|
||||
y = 0.4539736831952871
|
||||
y = 0.4527190879360086
|
||||
y = 0.4537659596983615
|
||||
y = 0.45500393252270654
|
||||
y = 0.4552026474557314
|
||||
y = 0.4546995780878234
|
||||
```
|
||||

|
||||
@ -0,0 +1,164 @@
|
||||
# Модуль 3 варианть 2
|
||||
Ефимова Людмила, А-03-23
|
||||
|
||||
Создайте модуль М1, содержащий две функции:
|
||||
|
||||
- функция 1: аргументы - имя текстового файла с числовыми данными (может быть разное число значений на каждой строке) и пороговое значение КК;
|
||||
считываются значения из указанного файла и записываются в два новых текстовых файла, имена которых совпадают с именем входного файла с добавлением 1 и 2 - в первый файл записываются значения, превышающие заданный порог, а во второй - не превышающие его.
|
||||
Исходные данные в виде списка возвращаются в вызывающую программу;
|
||||
|
||||
- функция 2: аргумент - имя текстового файла с исходными данными; считываются значения из указанного файла, формируются в виде списка и по нему рассчитываются: среднее, медиана, наименьшее и наибольшее значения, стандартное отклонение - это возвращаемые результаты функции.
|
||||
```py
|
||||
import math
|
||||
import statistics
|
||||
|
||||
def func1(filename, KK):
|
||||
with open(filename, 'r', encoding = 'utf-8') as f:
|
||||
nums = []
|
||||
for i in f:
|
||||
nums_line = list(map(float,line.strip().split()))
|
||||
nums.extend(nums_line)
|
||||
|
||||
above = []
|
||||
below = []
|
||||
for n in nums:
|
||||
if n > KK:
|
||||
above.append(n)
|
||||
else:
|
||||
below.append(n)
|
||||
|
||||
x = filename.split('.')[0]
|
||||
with open(x + '1.txt') as f: # запись в новый файл превышающих
|
||||
for num in above:
|
||||
f.write(str(num) +'\n')
|
||||
|
||||
with open(x + '2.txt') as f: # запись в новый файл не превышающих
|
||||
for num in below:
|
||||
f.write(str(num) +'\n')
|
||||
return nums
|
||||
|
||||
def func2(filename):
|
||||
with open(filename, 'r', encoding = 'utf-8') as f:
|
||||
nums = []
|
||||
for i in f:
|
||||
nums_line = list(map(float,line.strip().split()))
|
||||
nums.extend(nums_line)
|
||||
n = len(nums)
|
||||
mean = sum(nums)/n
|
||||
|
||||
median = statistics.median(nums) # медиана
|
||||
std = statistics.stdev(nums) # стандартное отклонение
|
||||
print(mean, median, min(nums), max(nums), std)
|
||||
|
||||
return [mean, median, min(nums), max(nums), std]
|
||||
```
|
||||
|
||||
Создайте еще один модуль М2, в котором должны:
|
||||
|
||||
- запрашиваться имя файла с исходными данными, проверяться его наличие и при отсутствии - повторение запроса;
|
||||
|
||||
- запрос порогового значения КК;
|
||||
|
||||
- вызов функции 1 с указанным именем;
|
||||
|
||||
- трижды вызвать функцию 2: с именем указанного в ответе на запрос файла, а также с каждым из файлов, созданных в функции 1; отобразить результаты расчетов.
|
||||
|
||||
```py
|
||||
import os
|
||||
|
||||
from M1 import func1, func2
|
||||
|
||||
def main():
|
||||
while True:
|
||||
filename = input("Исходный файл: ")
|
||||
if os.path.exists(filename):
|
||||
break
|
||||
print("Нет такого файла...")
|
||||
|
||||
KK = float(input("Введите пороговое значение K: "))
|
||||
data = func1(filename, KK)
|
||||
|
||||
x = filename.split('.')[0]
|
||||
|
||||
print("CТАТИСТИКИ")
|
||||
print("1. Исходный файл: ", func2(filename))
|
||||
print("2. Выше порога: ", func2(x + '1.txt'))
|
||||
print("3. Ниже порога: ", func2(x + '2.txt'))
|
||||
|
||||
return data
|
||||
```
|
||||
|
||||
Создайте модуль М0 - главную программу, которая вызывает М2, отображает исходные данные в виде графика и записывает их в бинарный файл RES2a.bin.
|
||||
```py
|
||||
import M2
|
||||
import matplotlib.pyplot as plt
|
||||
import pickle
|
||||
|
||||
if __name__ == "__main__":
|
||||
data = M2.main()
|
||||
|
||||
print("ГРАФИК:")
|
||||
|
||||
plt.figure(figsize=(12, 5))
|
||||
plt.plot(numbers)
|
||||
plt.axhline(y=k, color='r')
|
||||
plt.title(f"Данные из файла: {filename}")
|
||||
plt.xlabel("Номер элемента")
|
||||
plt.ylabel("Значение")
|
||||
plt.grid(True)
|
||||
plt.show()
|
||||
|
||||
with open("Res2a.bin", 'wb') as f:
|
||||
pickle.dump(data, f)
|
||||
```
|
||||
Подготовьте файл с не менее, чем с 20 числовыми значениями с разным числом элементов на разных строках и проверьте с ним разработанную программу.
|
||||
Создала файл datatest.txt с содержимым
|
||||
```py
|
||||
10 20 30 20
|
||||
22 33
|
||||
60 70 80 90
|
||||
15 23 25 27 76
|
||||
5 12 34 67 36
|
||||
```
|
||||
|
||||
Результат работы программы
|
||||
```py
|
||||
Введите имя файла (например: data.txt): datatest.txt
|
||||
Введите пороговое значение K: 23
|
||||
|
||||
СТАТИСТИКИ:
|
||||
1. Исходный файл: Среднее: 37.75, Медиана: 28.50, Мин: 5.00, Макс: 90.00, Отклонение: 26.02
|
||||
2. Выше порога: Среднее: 52.33, Медиана: 48.00, Мин: 25.00, Макс: 90.00, Отклонение: 23.73
|
||||
3. Ниже порога: Среднее: 15.88, Медиана: 17.50, Мин: 5.00, Макс: 23.00, Отклонение: 6.45
|
||||
|
||||
ГРАФИК:
|
||||
Данные сохранены в файл 'Res2a.bin'
|
||||
```
|
||||

|
||||
|
||||
Содержимое файла above:
|
||||
```py
|
||||
30.0
|
||||
33.0
|
||||
60.0
|
||||
70.0
|
||||
80.0
|
||||
90.0
|
||||
25.0
|
||||
27.0
|
||||
76.0
|
||||
34.0
|
||||
67.0
|
||||
36.0
|
||||
```
|
||||
Содержимое файла below:
|
||||
```py
|
||||
10.0
|
||||
20.0
|
||||
20.0
|
||||
22.0
|
||||
15.0
|
||||
23.0
|
||||
5.0
|
||||
12.0
|
||||
```
|
||||