Сравнить коммиты
2 Коммитов
| Автор | SHA1 | Дата | |
|---|---|---|---|
|
|
24c1a1e50e | ||
|
|
920a95b0c2 |
@@ -1,13 +1,10 @@
|
|||||||
# Индивидуальное контрольное задание
|
# Индивидуальное контрольное задание
|
||||||
Ефимова Людмила, А-03-23
|
Ефимова Людмила, А-03-23
|
||||||
|
|
||||||
## Задание вариант 17
|
## Задание 17
|
||||||
Создайте два списка: один – с фамилиями 3-х студентов вашей группы, другой – с 5 числами: 11,12,13,14,15.
|
Создайте два списка: один – с фамилиями 3-х студентов вашей группы, другой – с 5 числами: 11,12,13,14,15.
|
||||||
|
|
||||||
Напишите инструкцию создания словаря, в котором фамилии студентов были бы ключами, а числа – значениями.
|
Напишите инструкцию создания словаря, в котором фамилии студентов были бы ключами, а числа – значениями.
|
||||||
|
|
||||||
Отобразите получившийся словарь.
|
Отобразите получившийся словарь.
|
||||||
|
|
||||||
Отобразите его ключи с упорядочением по фамилиям студентов.
|
Отобразите его ключи с упорядочением по фамилиям студентов.
|
||||||
|
|
||||||
## Решение
|
## Решение
|
||||||
@@ -15,7 +12,7 @@
|
|||||||
familii = ['Ефимова', 'Девятова','Беженарь']
|
familii = ['Ефимова', 'Девятова','Беженарь']
|
||||||
num = [11, 12, 13, 14, 15]
|
num = [11, 12, 13, 14, 15]
|
||||||
dic = dict(zip(familii, num))
|
dic = dict(zip(familii, num))
|
||||||
print(dic)
|
dic
|
||||||
{'Ефимова': 11, 'Девятова': 12, 'Беженарь': 13}
|
{'Ефимова': 11, 'Девятова': 12, 'Беженарь': 13}
|
||||||
sorted(dic.keys())
|
sorted(dic.keys())
|
||||||
['Беженарь', 'Девятова', 'Ефимова']
|
['Беженарь', 'Девятова', 'Ефимова']
|
||||||
19
TEMA2/task22.md
Обычный файл
@@ -0,0 +1,19 @@
|
|||||||
|
# Индивидуальное контрольное задание
|
||||||
|
Ефимова Людмила, А-03-23
|
||||||
|
|
||||||
|
## Задание 17
|
||||||
|
Создайте два списка: один – с фамилиями 3-х студентов вашей группы, другой – с 5 числами: 11,12,13,14,15.
|
||||||
|
Напишите инструкцию создания словаря, в котором фамилии студентов были бы ключами, а числа – значениями.
|
||||||
|
Отобразите получившийся словарь.
|
||||||
|
Отобразите его ключи с упорядочением по фамилиям студентов.
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
```py
|
||||||
|
familii = ['Ефимова', 'Девятова','Беженарь']
|
||||||
|
num = [11, 12, 13, 14, 15]
|
||||||
|
dic = dict(zip(familii, num))
|
||||||
|
dic
|
||||||
|
{'Ефимова': 11, 'Девятова': 12, 'Беженарь': 13}
|
||||||
|
sorted(dic.keys())
|
||||||
|
['Беженарь', 'Девятова', 'Ефимова']
|
||||||
|
```
|
||||||
664
TEMA3/report3.md
@@ -1,664 +0,0 @@
|
|||||||
# Отчет по теме 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. Завершение работы со средой.
|
|
||||||
@@ -1,52 +0,0 @@
|
|||||||
# Индивидуальное контрольное задание модуль 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
|
|
||||||
['Помидор', 'Огурец', 'Сухарики', 'трюфель', 'Пицца', 'Чипсы', 'Яйца', 'Кофе', 'Молоко']
|
|
||||||
```
|
|
||||||
@@ -1,79 +0,0 @@
|
|||||||
# Общее контрольно задание по теме 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
|
|
||||||
['Создать', 'объект', ',', 'символьную', 'строку', 'с', 'текстом', 'предложения.']
|
|
||||||
```
|
|
||||||
Двоичные данные
TEMA4/Ris1.png
|
До Ширина: | Высота: | Размер: 42 KiB |
Двоичные данные
TEMA4/Ris2.png
|
До Ширина: | Высота: | Размер: 56 KiB |
Двоичные данные
TEMA4/Ris3.png
|
До Ширина: | Высота: | Размер: 34 KiB |
Двоичные данные
TEMA4/Ris4.png
|
До Ширина: | Высота: | Размер: 14 KiB |
Двоичные данные
TEMA4/Ris5.jpg
|
До Ширина: | Высота: | Размер: 38 KiB |
304
TEMA4/report4.md
@@ -1,304 +0,0 @@
|
|||||||
# Отчет по теме 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. Завершила работу со средой
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,61 +0,0 @@
|
|||||||
# Общее контрольное задание по теме 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
|
|
||||||
```
|
|
||||||
@@ -1,40 +0,0 @@
|
|||||||
# Индивидуальное контрольное задание по теме 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
|
|
||||||
```
|
|
||||||
Двоичные данные
TEMA5/Ris1.png
|
До Ширина: | Высота: | Размер: 114 KiB |
Двоичные данные
TEMA5/Ris2.png
|
До Ширина: | Высота: | Размер: 43 KiB |
290
TEMA5/report5.md
@@ -1,290 +0,0 @@
|
|||||||
# Отчет по теме 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. Завершила работу со средой и сохранила файл отчета.
|
|
||||||
@@ -1,94 +0,0 @@
|
|||||||
# Общее контрольное задание по теме 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
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
# Индивидуальное контрольное задание вариант 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
|
|
||||||
```
|
|
||||||
373
TEMA6/report6.md
@@ -1,373 +0,0 @@
|
|||||||
# Отчет по теме 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. Завершила работу со средой
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,90 +0,0 @@
|
|||||||
# Общее контрольное задание по теме 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']
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,55 +0,0 @@
|
|||||||
# Индивидуальное контрольное задание вариант 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
|
|
||||||
```
|
|
||||||
Двоичные данные
TEMA7/Ris1.png
|
До Ширина: | Высота: | Размер: 17 KiB |
Двоичные данные
TEMA7/Ris2.PNG
|
До Ширина: | Высота: | Размер: 22 KiB |
490
TEMA7/report7.md
@@ -1,490 +0,0 @@
|
|||||||
# Отчет по теме 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
|
|
||||||
|
|
||||||
@@ -1,53 +0,0 @@
|
|||||||
# Общее контрольное задание по теме 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
|
|
||||||
```
|
|
||||||
@@ -1,50 +0,0 @@
|
|||||||
# Индивидуальное контрольное задание вариант 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
|
|
||||||
банан
|
|
||||||
пум пум
|
|
||||||
ноль
|
|
||||||
```
|
|
||||||
@@ -1,2 +0,0 @@
|
|||||||
import MM2
|
|
||||||
print("y =", MM2.vyhod)
|
|
||||||
21
TEMA8/MM1.py
@@ -1,21 +0,0 @@
|
|||||||
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
|
|
||||||
21
TEMA8/MM2.py
@@ -1,21 +0,0 @@
|
|||||||
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)
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
def read(name):
|
|
||||||
nums = []
|
|
||||||
fp=open(name)
|
|
||||||
for i in fp:
|
|
||||||
for y in i.strip().split():
|
|
||||||
nums.append(float(y))
|
|
||||||
return nums
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
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
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
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))
|
|
||||||
363
TEMA8/report8.md
@@ -1,363 +0,0 @@
|
|||||||
# Отчет по теме 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. Завершила работу со средой
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,55 +0,0 @@
|
|||||||
# Общее контрольное задание по теме 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
|
|
||||||
```
|
|
||||||
@@ -1,48 +0,0 @@
|
|||||||
# Индивидуальное контрольное задание вариант 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
|
|
||||||
```
|
|
||||||
Двоичные данные
TEMA9/Ris1.png
|
До Ширина: | Высота: | Размер: 53 KiB |
Двоичные данные
TEMA9/Ris10.PNG
|
До Ширина: | Высота: | Размер: 42 KiB |
Двоичные данные
TEMA9/Ris2.png
|
До Ширина: | Высота: | Размер: 57 KiB |
289
TEMA9/report9.md
@@ -1,289 +0,0 @@
|
|||||||
# Отчет по теме 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
|
|
||||||
```
|
|
||||||

|
|
||||||
164
TEMA9/task9.md
@@ -1,164 +0,0 @@
|
|||||||
# Модуль 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
|
|
||||||
```
|
|
||||||