# Отчет по Теме 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 Внес в словарь две строки, перед эти объединив их в список - одному ключу одно значение.