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

349 строки
17 KiB
Markdown

# Отчет по теме 2
Хатюхин Евгений, А-02-23
## 1 Создание протокола и настройка рабочей среды
## 2 Простые объекты
Я создал 2 простых объекта, проверил их значения, убедился, что они присутствуют в памяти компьютера, узнал тип одного из объектов, удалил эти объекты и убедился, что они пропали из памяти компьютера.
```py
f1=16; f2=3
f1,f2
(16, 3)
dir()
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'f1', 'f2']
dir(f1)
['__abs__', '__add__', '__and__', '__bool__', '__ceil__', '__class__', '__delattr__', '__dir__', '__divmod__', '__doc__', '__eq__', '__float__', '__floor__', '__floordiv__', '__format__', '__ge__', '__getattribute__', '__getnewargs__', '__getstate__', '__gt__', '__hash__', '__index__', '__init__', '__init_subclass__', '__int__', '__invert__', '__le__', '__lshift__', '__lt__', '__mod__', '__mul__', '__ne__', '__neg__', '__new__', '__or__', '__pos__', '__pow__', '__radd__', '__rand__', '__rdivmod__', '__reduce__', '__reduce_ex__', '__repr__', '__rfloordiv__', '__rlshift__', '__rmod__', '__rmul__', '__ror__', '__round__', '__rpow__', '__rrshift__', '__rshift__', '__rsub__', '__rtruediv__', '__rxor__', '__setattr__', '__sizeof__', '__str__', '__sub__', '__subclasshook__', '__truediv__', '__trunc__', '__xor__', 'as_integer_ratio', 'bit_count', 'bit_length', 'conjugate', 'denominator', 'from_bytes', 'imag', 'is_integer', 'numerator', 'real', 'to_bytes']
type(f2)
<class 'int'>
del f1,f2
dir()
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__']
```
## 3 Изучил правила именования объектов в пайтон и проверил их на практике
```py
gg1=1.6 #значение в виде вещественного числа
hh1='Строка' #значение в виде символьной строки
73sr=3 #неправильное имя – начинается с цифры - будет диагностика!
SyntaxError: invalid decimal literal
and=7 #недопустимое имя – совпадает с ключевым словом - будет диагностика!
SyntaxError: invalid syntax
dir()
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'gg1', 'hh1']
```
## 4 Просмотрел список ключевых слов и присвоил его переменной
```py
import keyword
keyword.kwlist
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
kl = keyword.kwlist
kl
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
```
## 5 Просмотрел список встроенных идентификаторов и изучил некоторые из них с помощью функции help
- abs - выдает значение по модулю
- len - выдает длину объекта
- max - выдает максимальное число из списка введенных в аргумент
- min - выдает минимальное число из списка введенных в аргумент
- pow - при двух аргументах: возводит первый в степень второго. При наличие третьего аргумента делит получившийся результат на третий аргумент и показывает остаток
- round - округляет число до целого ,если 1 аргумент. При наличие второго аргумента округляет до стольких цифр после запятой, сколько указано во втором аргументе
- sorted - сортирует числа или буквы по возрастанию или убыванию
- sum - суммирует числа
- zip - создает итератор, который объединяет элементы из нескольких перебираемых объектов по соответствию.
```py
import builtins
dir(builtins)
['ArithmeticError', 'AssertionError', 'AttributeError', 'BaseException', 'BaseExceptionGroup', 'BlockingIOError', 'BrokenPipeError', 'BufferError', 'BytesWarning', 'ChildProcessError', 'ConnectionAbortedError', 'ConnectionError', 'ConnectionRefusedError', 'ConnectionResetError', 'DeprecationWarning', 'EOFError', 'Ellipsis', 'EncodingWarning', 'EnvironmentError', 'Exception', 'ExceptionGroup', 'False', 'FileExistsError', 'FileNotFoundError', 'FloatingPointError', 'FutureWarning', 'GeneratorExit', 'IOError', 'ImportError', 'ImportWarning', 'IndentationError', 'IndexError', 'InterruptedError', 'IsADirectoryError', 'KeyError', 'KeyboardInterrupt', 'LookupError', 'MemoryError', 'ModuleNotFoundError', 'NameError', 'None', 'NotADirectoryError', 'NotImplemented', 'NotImplementedError', 'OSError', 'OverflowError', 'PendingDeprecationWarning', 'PermissionError', 'ProcessLookupError', 'PythonFinalizationError', 'RecursionError', 'ReferenceError', 'ResourceWarning', 'RuntimeError', 'RuntimeWarning', 'StopAsyncIteration', 'StopIteration', 'SyntaxError', 'SyntaxWarning', 'SystemError', 'SystemExit', 'TabError', 'TimeoutError', 'True', 'TypeError', 'UnboundLocalError', 'UnicodeDecodeError', 'UnicodeEncodeError', 'UnicodeError', 'UnicodeTranslateError', 'UnicodeWarning', 'UserWarning', 'ValueError', 'Warning', 'WindowsError', 'ZeroDivisionError', '_', '_IncompleteInputError', '__build_class__', '__debug__', '__doc__', '__import__', '__loader__', '__name__', '__package__', '__spec__', 'abs', 'aiter', 'all', 'anext', 'any', 'ascii', 'bin', 'bool', 'breakpoint', 'bytearray', 'bytes', 'callable', 'chr', 'classmethod', 'compile', 'complex', 'copyright', 'credits', 'delattr', 'dict', 'dir', 'divmod', 'enumerate', 'eval', 'exec', 'exit', 'filter', 'float', 'format', 'frozenset', 'getattr', 'globals', 'hasattr', 'hash', 'help', 'hex', 'id', 'input', 'int', 'isinstance', 'issubclass', 'iter', 'len', 'license', 'list', 'locals', 'map', 'max', 'memoryview', 'min', 'next', 'object', 'oct', 'open', 'ord', 'pow', 'print', 'property', 'quit', 'range', 'repr', 'reversed', 'round', 'set', 'setattr', 'slice', 'sorted', 'staticmethod', 'str', 'sum', 'super', 'tuple', 'type', 'vars', 'zip']
abs(-10)
10
len("len")
3
max(1,25)
25
min(1,25)
1
pow(2,3)
8
pow(2,3,3)
2
round(2.85)
3
round(2.855,2)
2.85
round(2.856,2)
2.86
sorted("cba")
['a', 'b', 'c']
sum([3,7])
10
list(zip([1,2,3],['a','b','c']))
[(1, 'a'), (2, 'b'), (3, 'c')]
```
## 6 Убедился, что переменные чувствительны к регистру
```py
Gg1 = 45
gg1
1.6
Gg1
45
```
## 7 Изучил простые базовые объекты
### 7.1 Изучил логический тип данных(bool)
```py
bb1=True; bb2=False
bb1;bb2
True
False
type(bb1)
<class 'bool'>
```
### 7.2 Изучил другие простые типы данных(int,float,complex)
```py
ii1=-1234567890
ff1=-8.9876e-12 #экспоненциальная форма записи вещественного числа
dv1=0b1101010 #Это – двоичное число. В объекте какого класса оно сохранено?
type(dv1)
<class 'int'>
vsm1=0o52765 #Это – восьмеричное число
type(vsm1)
<class 'int'>
shest1=0x7109af6 #Это – шестнадцатеричное число
type(shest1)
<class 'int'>
cc1=2-3j
type(cc1)
<class 'complex'>
a=3.67; b=-0.45
cc2=complex(a,b) #Создается комплексное число
```
### 7.3 Изучил тип объекта - строка-символ
```py
ss1='Это - строка символов'
ss1
'Это - строка символов'
ss1="Это - строка символов"
ss1
'Это - строка символов'
ss1a="Это - \" строка символов \", \n \t выводимая на двух строках"
print(ss1a)
Это - " строка символов ",
выводимая на двух строках
ss1b= 'Меня зовут: \n Хатюхин Е.С.'
ss1b
'Меня зовут: \n Хатюхин Е.С.'
ss1b='Меня зовут: \n Хатюхин Е.С.'
print(ss1b)
Меня зовут:
Хатюхин Е.С.
mnogo="""Нетрудно заметить , что в результате операции
над числами разных типов получается число,
имеющее более сложный тип из тех, которые участвуют в операции."""
print(mnogo)
Нетрудно заметить , что в результате операции
над числами разных типов получается число,
имеющее более сложный тип из тех, которые участвуют в операции.
ss1[0] #Это – символ «Э»
'Э'
ss1[8] #А это – символ «р»
'р'
ss1[-2] #А это – символ «о» (при знаке «-»(минус) отсчет от конца строки)
'о'
ss1[6:9] #Это часть строки – символы с 6-го индекса по 8-й (9-й не включается!)
'стр'
ss1[13:] #Это часть строки – с 13-го индекса и до конца
'символов'
ss1[:13] #Это часть строки – с начала и до 12-го индекса включительно
'Это - строка '
ss1[5:-8] #Это часть строки – с 5-го индекса и до 8-го от конца
' строка '
ss1[3:17:2] #Часть строки – с 3-го по 16-й индексы с шагом 2
' тоасм'
ss1[17:3:-2]
'омсаот '
ss1[-4:3:-2]
'омсаот '
ss1[4]='=' # Будет диагностика!
Traceback (most recent call last):
File "<pyshell#23>", line 1, in <module>
ss1[4]='=' # Будет диагностика!
TypeError: 'str' object does not support item assignment
ss2 = ss1[:6] + ss1b[-12:]
ss2
'Это - Хатюхин Е.С.'
```
## 8 Изучил более сложные типы данных
### 8.1 Изучил список и проверил на практике некоторые его методы
```py
spis1=[111,'Spisok',5-9j]
stup=[0,0,1,1,1,1,1,1,1]
spis=[1,2,3,4,
5,6,7,
8,9,10]
spis1[-1]
(5-9j)
stup[-8::2] # вошло 4 элемента, начиная со 2 через 1(если по индексам: 1,3,5,7)
[0, 1, 1, 1]
spis1[1]='Список'
spis1
[111, 'Список', (5-9j)]
len(spis1)
3
help(spis1.append)
Help on built-in function append:
append(object, /) method of builtins.list instance
Append object to the end of the list.
spis1.append('New item') # В конец списка добавлен элемент «New item»
spis1+['New item']
[111, 'Список', (5-9j), 'New item', 'New item']
spis1.append('New item') # В конец списка добавлен элемент «New item»
spis1.append(ss1b)
spis1
[111, 'Список', (5-9j), 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.']
spis1.pop(1) #Из списка удален элемент с индексом 1
'Список'
```
Методы:
- insert - вставляет элемент соответствующий второму аргументу на индекс равный первому аргументу
- remove - удаляет первый элемент из списка, который соответствует значению аргумента
- extend - добaвляет в конец списка все элемента из объекта в аргументе
- sort - сортирует элементы по порядку
- reverse - переворачивает порядок элементов списка
- copy - создает копию списка
- count - возвращает число, сколько раз элемент из аргумента встречается в списке
- index - возвращает индекс первого вхождения элемента соответствующему аргументу.
- clear - очищает список
```py
stup.insert(1,2)
stup
[0, 2, 0, 1, 1, 1, 1, 1, 1, 1]
stup.insert(2,123)
stup
[0, 2, 123, 0, 1, 1, 1, 1, 1, 1, 1]
stup.remove(123)
stup
[0, 2, 0, 1, 1, 1, 1, 1, 1, 1]
last = [4,6,8
]
stup.extend(last)
stup
[0, 2, 0, 1, 1, 1, 1, 1, 1, 1, 4, 6, 8]
stup.sort()
stup
[0, 0, 1, 1, 1, 1, 1, 1, 1, 2, 4, 6, 8]
stup.reverse()
stup
[8, 6, 4, 2, 1, 1, 1, 1, 1, 1, 1, 0, 0]
stup.copy()
[8, 6, 4, 2, 1, 1, 1, 1, 1, 1, 1, 0, 0]
stup.count(1)
7
stup.index(2)
3
stup.clear()
stup
[]
```
```py
spis2=[spis1,[4,5,6,7]] #здесь элементами являются два списка
spis2[0][1] #обращение к элементу списка spis1
(5-9j)
spis2[0][1]=78 #Убедитесь, что значение элемента заменено на 78
spis2[0][1]
78
spis1
[111, 78, 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.']
# список 1 изменился, потому что он входит в элементы списка 2 не как копия, а как ссылка, поэтому любое изменение элементов списка 1 через список 2 приведет к изменению списка 1 как отделной переменной
a = 5
b = True
spisok = [a,ss2,b,spis1]
spisok
[5, 'Это - Хатюхин Е.С.', True, [111, 78, 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.']]
```
### 8.2 Изучил объект-кортеж
```py
kort1=(222,'Kortezh',77+8j)
kort1= kort1+(1,2)
kort1
(222, 'Kortezh', (77+8j), 1, 2)
kort1= kort1+(ss1b,)
kort1
(222, 'Kortezh', (77+8j), 1, 2, 'Меня зовут: \n Хатюхин Е.С.')
kort2=kort1[:2]+kort1[3:]
kort2
(222, 'Kortezh', 1, 2, 'Меня зовут: \n Хатюхин Е.С.')
kort1.index(2) # Будет получено значение 4
4
kort1.count(222) #Будет получено значение 1
1
kort1[2]=90 #Будет получена диагностика о невозможности изменения кортежа
Traceback (most recent call last):
File "<pyshell#98>", line 1, in <module>
kort1[2]=90 #Будет получена диагностика о невозможности изменения кортежа
TypeError: 'tuple' object does not support item assignment
korteg = (a,ss1,b,spisok,kort1)
korteg
(5, 'Это - строка символов', True, [5, 'Это - Хатюхин Е.С.', True, [111, 78, 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.']], (222, 'Kortezh', (77+8j), 1, 2, 'Меня зовут: \n Хатюхин Е.С.'))
```
### 8.3 Изучил объект-словарь
```py
dic1={'Saratov':145, 'Orel':56, 'Vologda':45}
dic1
{'Saratov': 145, 'Orel': 56, 'Vologda': 45}
dic1['Orel']
56
dic1['Pskov']=78
dic1
{'Saratov': 145, 'Orel': 56, 'Vologda': 45, 'Pskov': 78}
sorted(dic1.keys())
['Orel', 'Pskov', 'Saratov', 'Vologda']
sorted(dic1.values())
[45, 56, 78, 145]
dic2={1:'mean',2:'standart deviation',3:'correlation'}
dic3={'statistics':dic2,'POAS':['base','elementary','programming']}
dic3['statistics'][2]
'standart deviation'
dic4=dict([(1,['A','B','C']),(2,[4,5]),('Q','Prim'),('Stroka',ss1b)])
dic5=dict(zip(['A','B','C','Stroka'],[16,-3,9,ss1b]))
kort7 = (1,2,3,4,5,6,7)
kort7
(1, 2, 3, 4, 5, 6, 7)
lis5 = ['a','b','c','d','e']
lis5
['a', 'b', 'c', 'd', 'e']
dic6 = dict(zip(kort7,lis5))
dic6
{1: 'a', 2: 'b', 3: 'c', 4: 'd', 5: 'e'}
#Длинна нашего словаря равна 5, поскольку zip объединяет элементы в словарь по минимальной длинне аргументов
AVTI={'Курс I':[22,23,17,24,30,29,28,25,23,0,4,31,30,33,18,12,27],'Курс II':[18,16,12,15,29,18,21,23,13,0,4,20,31,26,16,], 'Курс III':[17,12,0,6,17,15,19,19,0,0,5,17,22,18,12], 'Курс IV':[27,16,0,13,17,15,19,20,0,0,2,15,18,16,17]}
AVTI['Курс III'][5]
15
```
### 8.4 Изучил объект-множество
```py
mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'}
mnoz1
{'двигатель', 'датчик', 'микропроцессор', 'линия связи'}
len(mnoz1)
4
'датчик' in mnoz1
True
mnoz1.add('реле')
mnoz1.remove('линия связи')
mnoz2 = {1, True, long, int, 24, Евгений}
Traceback (most recent call last):
File "<pyshell#136>", line 1, in <module>
mnoz2 = {1, True, long, int, 24, Евгений}
NameError: name 'long' is not defined
mnoz2 = {1, True, 'long', 'int', 24, 'Евгений'}
mnoz2
{1, 24, 'int', 'Евгений', 'long'}
'True' in mnoz2
False
mnoz2.add("True")
'True' in mnoz2
True
```
## 9 Завершил сеанс работы в IDLE