diff --git a/TEMA2/report.md b/TEMA2/report.md new file mode 100644 index 0000000..983067a --- /dev/null +++ b/TEMA2/report.md @@ -0,0 +1,529 @@ +# Отчет по Теме 2 + +Савин Семён, А-02-23 + +## Пункт 2. Изучение простых объектов + +Переменным f1 и f2 были присвоены значения (целые числа). +```py +>>> import os +>>> os.chdir ('C:\\Users\\somas\\python-labs\\TEMA2') +>>> f1 = 16; f2 = 3 +>>> f1, f2 +(16, 3) +>>> f1;f2 +16 +3 +``` + +Проверяем, какие объекты есть в среде python, а также выводим атрибуты для переменной f1. +```py +>>> dir() +['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'f1', 'f2', 'os'] +>>> dir(f1) +['__abs__', '__add__', '__and__', '__bool__', '__ceil__', '__class__', '__delattr__', '__dir__', '__divmod__', '__doc__', '__eq__', '__float__', '__floor__', '__floordiv__', '__format__', '__ge__', '__getattribute__', '__getnewargs__', '__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_length', 'conjugate', 'denominator', 'from_bytes', 'imag', 'numerator', 'real', 'to_bytes'] +``` +Выводим класс переменной f2 и удаляем обе переменные с проверкой удаления. + +```py +>>> type (f2) + +>>> del f1,f2 +>>> f1,f2 +Traceback (most recent call last): + File "", line 1, in + f1,f2 +NameError: name 'f1' is not defined +>>> f2 +Traceback (most recent call last): + File "", line 1, in + f2 +NameError: name 'f2' is not defined +``` + +## Пункт 3. Правила именования объектов +Создал несколько переменных разных типов, а также с неверным названием. +```py +>>> ggl = 1.6 +>>> hhl = 'Строка' +>>> 73sr = 3 +SyntaxError: invalid syntax +>>> and = 7 +SyntaxError: invalid syntax +``` +## Пункт 4. Просмотр ключевых слов + +Был выведен и сохранен в переменной keylist список ключевых слов. +```py +>>> keyword.kwlist +['False', 'None', 'True', '__peg_parser__', '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'] +>>> keylist = keyword.kwlist +>>> keylist +['False', 'None', 'True', '__peg_parser__', '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. Просмотр встроенных идентификаторов + +Получен список встроенных идентификаторов + +>>> import builtins +>>> dir(builtins) +['ArithmeticError', 'AssertionError', 'AttributeError', 'BaseException', 'BlockingIOError', 'BrokenPipeError', 'BufferError', 'BytesWarning', 'ChildProcessError', 'ConnectionAbortedError', 'ConnectionError', 'ConnectionRefusedError', 'ConnectionResetError', 'DeprecationWarning', 'EOFError', 'Ellipsis', 'EnvironmentError', 'Exception', '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', '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', '_', '__build_class__', '__debug__', '__doc__', '__import__', '__loader__', '__name__', '__package__', '__spec__', 'abs', 'all', '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 - модуль от числа +max/min - вывод максимального/минимального числа для либо списка либо для нескольких перечисленных переменных +len - выводит кол-во объектов в контейнере +pow - возводит число в степень +round - округляет число +sum - дает сумму всех элементов в контейнере +sorted - сортирует по возрастанию элементы в контейнере +zip - "сшивает" значения из одной последовательности значений с соответвтвующими значениями из другой + +```py +>>> x = -3 +>>> abs(x) +3 +>>> pow(x,2) +9 +>>> x = 1.576 +>>> round(x) +2 +>>> x = 1.50 +>>> round(x) +2 +``` + +## Пункт 6. Значимость регистра + +При присваивании имен переменным важен также регистр букв. + +```py +>>> x = 1.576 +>>> round(x) +2 +>>> x = 1.50 +>>> round(x) +2 +``` + +## Пункт 7. Изучение простых базовых типов. + +## 7.1. Логический тип + +```py +>>> bb1 = True; bb2 = False +>>> bb1,bb2 +(True, False) +>>> type(bb1) + +``` + +## 7.2. Другие простые типы + +Изучены некоторые другие типы числовых переменных + +```py +>>> ii1 = -1234567890 +>>> type(ii1) + +>>> ff1 = -8.9876e-12 +>>> type(ff1) + +>>> dv1 = 0b1101010 +>>> type(dv1) + +>>> vsm1 = 0o52765 +>>> shest1 = 0x7109af6 +>>> ccl = 2-3j +>>> a = 3.67; b = -0.45 +>>> cc2 = complex(a,b) +>>> cc2 +(3.67-0.45j) +>>> type(cc2) + +``` + +## 7.3. Строка + +Также изучили разные способы вывода простой строки с помощью "экранированных последовательностей" + +```py +>>> ss1 = 'this is a string' +>>> print(ss1) +this is a string +>>> ss1a = "this is a \" string \", \n \t printed on two lines" +>>> print(ss1a) +this is a " string ", + printed on two lines +>>> ss1b = "my name is: \n Savin S.A." +>>> print(ss1b) +my name is: + Savin S.A. +``` + +Также вывели многострочное предложение с помощью тройных кавычек + +```py +>>> mnogo="""Нетрудно заметить , что в результате операции +над числами разных типов получается число, +имеющее более сложный тип из тех, которые участвуют в операции.""" +>>> print(mnogo) +Нетрудно заметить , что в результате операции +над числами разных типов получается число, +имеющее более сложный тип из тех, которые участвуют в операции. +``` + +Изучил действия со сторокой - вывд определенных букв по индексу в строке, а так же разрезание строки(с шагами 1 и 2) + +```py +>>> ss1[0] +'t' +>>> ss1[8] +'a' +>>> ss1[-2] +'n' +>>> ss1[6:9] +'s a' +>>> ss1[13:] +'ing' +>>> ss1[5:-8] +'is ' +>>> ss1[3:17:2] +'si tig' +>>> ss1[17:3:-2] +'git i' +>>> ss1[-4:3:-2] +'rsas ' +``` +(Изначальная строка - this is a string) + +При изменении строки случается ошибка - так как строка неизменяема. Однако при переопределении можно внести изменения. + +```py +>>> ss1[4] = '=' +Traceback (most recent call last): + File "", line 1, in + ss1[4] = '=' +TypeError: 'str' object does not support item assignment +>>> ss1 = ss1[:4] + '+' + ss1[5:] +>>> ss1 +'this+is a string' +``` + +Самостоятельно поработал со строкой ss1b - двухстрочное предложение. А также удалил старые значения x,y, заменив на другие. +Проверил их тип. + +```py +>>> ss1b[4:17:2] +'aei:\nSv' +>>> ss1b[16:] +'vin S.A.' +>>> ss1b[14:] +'Savin S.A.' +>>> del x +>>> del y +>>> x = True +>>> y = 14-5j +>>> type(x);type(y) + + +``` + +## Пункт 8. Изучение более сложных типов. + +## 8.1. Список + +Работа со списками - можно задать любые значение и типы. Список - упорядоченная коллекция объектов. +```py +>>> spis1 = [111,'spisok', 5-9j] +>>> spis1 +[111, 'spisok', (5-9j)] +>>> stup=[0,0,1,1,1,1,1,1,1] +>>> stup +[0, 0, 1, 1, 1, 1, 1, 1, 1] +>>> spis = [1,2,3,4, + 5,6,7,8, + 9,10] +>>> spis +[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] +``` +Также по индексу можно сослаться на определенные элементы. Или перечислить с некоторым шагом. + +```py +>>> spis[-1] +10 +>>> stup[-8::2] +[0, 1, 1, 1] +>>> spis[-9::2] +[2, 4, 6, 8, 10] +``` + +Списки можно изменять, меняя элементы и переписывая их. + +```py +>>> spis1[1] = 'Список' +>>> spis1 +[111, 'Список', (5-9j)] +``` + +len(...) возвращает длину списка(количестево элементов в контейнере) +spis1.append(элемент) добавляет элемент в конец списка +spis1+[элемент] - добавляет элемент на вывод 1 раз. Не вписывает этот элемент в список +spis1.pop(индекс элемента) - удаляет элемент с указанным индексом +spis1.reverse - переворачивает список +spis1.insert(индекс, элемент) - вставляет элемент после элемента с указанным индексом +spis1.extend(список) - присоединяет в конец другой список +spis1.remove(элемент) - удаляет первый встреченный элемент равный указанному +spis1.sort() - сортирует список в порядке возрастания +spis1.copy() - создает поверхностную копию(shallow copy) +spis1.index(элемент) - возвращает индекс первого соответсвующего элемента +spis1.clear() - очищает список +spis1.count(элемент) - считает кол-во соответствующих элементов + +```py +>>> len(spis) +10 +>>> 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') +>>> spis1 +[111, 'Список', (5-9j), 'New item'] +>>> spis1+['Newest item'] +[111, 'Список', (5-9j), 'New item', 'Newest item'] +>>> spis1 +[111, 'Список', (5-9j), 'New item'] +>>> spis1.append(ss1b) +>>> spis1 +[111, 'Список', (5-9j), 'New item', 'my name is: \n Savin S.A.'] +>>> spis1.pop(1) +'Список' +>>> spis1 +[111, (5-9j), 'New item', 'my name is: \n Savin S.A.'] +>>> spis1.reverse + +>>> spis1 +[111, (5-9j), 'New item', 'my name is: \n Savin S.A.'] +>>> spis1.reverse() +>>> spis1 +['my name is: \n Savin S.A.', 'New item', (5-9j), 111] +>>> spis1.insert(2, 2+ 2j) +>>> spis1 +['my name is: \n Savin S.A.', 'New item', (2+2j), (5-9j), 111] +>>> spis1.extend(spis) +>>> spis1 +['my name is: \n Savin S.A.', 'New item', (2+2j), (5-9j), 111, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10] +>>> spis1.append('New item') +>>> spis1 +['my name is: \n Savin S.A.', 'New item', (2+2j), (5-9j), 111, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 'New item'] +>>> spis1.remove('New item') +>>> spis1 +['my name is: \n Savin S.A.', (2+2j), (5-9j), 111, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 'New item'] +>>> spis1.count(1) +1 +>>> spis1.index(10) +13 +>>> spis.clear() +>>> spis1.clear() +>>> spis1 +[] +>>> spis +[] +``` + +Далее создаем вложенные списки. Здесь я также попробовал применить spis2.copy() и проверить как работает поверхностная копия. +В итоге сделан вывод - изменения в копии не вносятся только на первом уровне. Если поменять вложенный список, то он поменяется и для оригинала. +Тут же я самостоятельно изменил вложенный элемент при помощи append. После изменил значения элемента во вложенном списке. + +```py +>>> spis1 = (1,2,3) +>>> spis1 = [1,2,3] +>>> spis1 +[1, 2, 3] +>>> spis2 = [spis1,[4,5,6,7]] +>>> spis2 +[[1, 2, 3], [4, 5, 6, 7]] +>>> copytest = spis2.copy() +>>> copytest +[[1, 2, 3], [4, 5, 6, 7]] +>>> spis2 +[[1, 2, 3], [4, 5, 6, 7]] +>>> copytest.append(3) +>>> copytest +[[1, 2, 3], [4, 5, 6, 7], 3] +>>> spis2 +[[1, 2, 3], [4, 5, 6, 7]] +>>> copytest +[[1, 2, 3], [4, 5, 6, 7], 3] +>>> copytest[1].append(2) +>>> copytest +[[1, 2, 3], [4, 5, 6, 7, 2], 3] +>>> spis2 +[[1, 2, 3], [4, 5, 6, 7, 2]] +>>> spis2 +[[1, 2, 3], [4, 5, 6, 7, 2]] +>>> spis2[0] = 78 +>>> spis2 +[78, [4, 5, 6, 7, 2]] +``` + +## 8.2. Кортеж + +Работа с кортежами - их нельзя изменять, но можно переопределять, таким образом внося изменения. + +```py +>>> kort1 = (222,'Kortezh', 77+8j) +>>> 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, 'my name is: \n Savin S.A.') +>>> kort2 = kort1[:2] + kort1[3:] +>>> kort2 +(222, 'Kortezh', 1, 2, 'my name is: \n Savin S.A.') +>>> kort2.index(2) +3 +>>> kort2.count(222) +1 +>>> kort2[2] = 90 +Traceback (most recent call last): + File "", line 1, in + kort2[2] = 90 +TypeError: 'tuple' object does not support item assignment +``` + +## 8.3. Словарь + +Работа со словарями. Ключи - неизменяемы. + +```py +>>> 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] +>>> dic1 +{'Saratov': 145, 'Orel': 56, 'Vologda': 45, 'Pskov': 78} +>>> dic2={1:'mean', 2:'standart deviation', 3:'correlation'} +>>> dic2 +{1: 'mean', 2: 'standart deviation', 3: 'correlation'} +>>> dic3={'statistics':dic2, 'POAS':['base','elementary','programming']} +>>> dic3 +{'statistics': {1: 'mean', 2: 'standart deviation', 3: 'correlation'}, 'POAS': ['base', 'elementary', 'programming']} +>>> dic3['statistics'][2] +'standart deviation' +>>> dic4=dict([(1,['A','B','C']),(2,[4,5]),('Q','Prim'),('Stroka',ss1b)]) +>>> dic4 +{1: ['A', 'B', 'C'], 2: [4, 5], 'Q': 'Prim', 'Stroka': 'my name is: \n Savin S.A.'} +>>> dic5 = dict(zip(['A','B','C','Stroka'],[16,-3,9,ss1b])) +>>> dic5 +{'A': 16, 'B': -3, 'C': 9, 'Stroka': 'my name is: \n Savin S.A.'} +``` + +Свой словарь состоит из 5 элементов, потому что мы "сшили" два контейнера, длина определилась по минимальному кол-ву. + +```py +>>> testkort = ('B','S','M','H','D','A','R') +>>> testlist = ['bow','sword','mace','helbard','dirk'] +>>> dictest=dict(zip(testkort,testlist)) +>>> dictest +{'B': 'bow', 'S': 'sword', 'M': 'mace', 'H': 'helbard', 'D': 'dirk'} +``` +## 8.4. Множество + +Множества могут состоять только из неповторяющихся неизменяемых элементов - при создании множества со списком выведет ошибку. + +```py +>>> mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'} +>>> mnoz1 +{'линия связи', 'датчик', 'микропроцессор', 'двигатель'} +>>> len(mnoz1) +4 +>>> 'датчик' in mnoz1 +True +>>> mnoz1.add('htkt') +>>> mnoz1.remove('htkt') +>>> mnoz1.add('реле') +>>> mnoz1 +{'датчик', 'двигатель', 'микропроцессор', 'линия связи', 'реле'} +>>> mnoz1.remove('линия связи') +>>> mnoz1 +{'датчик', 'двигатель', 'микропроцессор', 'реле'} +>>> mnoz2 = {'дерево', 15, 78, [6,7,8]} +Traceback (most recent call last): + File "", line 1, in + mnoz2 = {'дерево', 15, 78, [6,7,8]} +TypeError: unhashable type: 'list' +>>> kortmnoz = (7,8,7,8) +>>> mnoz2 = {'дерево', 16, 19, kortmnoz} +>>> mnoz2 +{16, (7, 8, 7, 8), 19, 'дерево'} +>>> mnoz2.add(kort1) +>>> mnoz2 +{(222, 'Kortezh', (77+8j), 1, 2, 'my name is: \n Savin S.A.'), 16, (7, 8, 7, 8), 19, 'дерево'} +>>> mnoz2.remove('дерево') +>>> mnoz2 +{(222, 'Kortezh', (77+8j), 1, 2, 'my name is: \n Savin S.A.'), 16, (7, 8, 7, 8), 19} +>>> len(mnoz2) +4 +``` + +# Общее контрольное задаие по теме 2 + +Савин Семён, А-02-23 + +##Задание + +1) Создать переменную с именем familia и со значением - символьной строкой – своей фамилией в латинской транскрипции. +2) Создать переменную со значением, совпадающим с первой буквой из familia. +3) Создать переменную с именем sp_kw со значением – списком всей ключевых слов языка Python. +4) Удалите из списка sp_kw значение 'nonlocal'. Выводом списка в командном окне IDLE убедитесь, что это значение удалено из списка. +5) Создайте кортеж kort_nam с именами: вашим и еще 3-х студентов из вашей группы. Напишите инструкцию, позволяющую убедиться, что тип переменной – это tuple. +6) Напишите инструкцию, добавляющую в kort_nam имена еще двух студентов. +7) Напишите инструкцию, позволяющую определить, сколько раз в кортеже присутствуют студенты с именем «Дима». +8) Создайте словарь dict_bas, в котором ключами являются русские названия типов переменных, использованных в предыдущих операторах, а значениями – ранее созданные переменные, соответствующие этим типам. + +## Решение + +```py +>>> familia = 'Savin' +>>> familia +'Savin' +>>> bukva = familia[0] +>>> bukva +'S' +>>> sp_kv = keyword.kwlist +>>> sp_kv +['False', 'None', 'True', '__peg_parser__', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield'] +>>> sp_kv.remove('nonlocal') +>>> sp_kv +['False', 'None', 'True', '__peg_parser__', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield'] +>>> kort_nam = ('Семён', 'Ярослав', 'Миша') +>>> type(kort_nam) + +>>> kort_nam.count('Дима') +0 +>>> dict_bas = {'Строка': [familia,bukva], 'Список': sp_kv, 'Кортеж': kort_nam} +>>> dict_bas +{'Строка': ['Savin', 'S'], 'Список': ['False', 'None', 'True', '__peg_parser__', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield'], 'Кортеж': ('Семён', 'Ярослав', 'Миша')} + +``` + +Для работы со строкой использовал ссылку по индексу, отпечатал первую букву. +Для работы со списком присвоил значению sp_kv keyword.kwlist - это уже список, поэтому без [] +В кортеж не записано имен "Дима", kort_nam.count('Дима') выводит 0 +Внес в словарь две строки, перед эти объединив их в список - одному ключу одно значение.