# Отчёт по Теме 2 Кузьменко Елена, А-02-23 ## 1.Работа в оболочке IDLE. Задание рабочего каталога. ```py >>> import os >>> os.chdir(r"C:\Users\Admin\Desktop\python-labs\TEMA2") >>> os.getcwd() 'C:\\Users\\Admin\\Desktop\\python-labs\\TEMA2' ``` Был открыт текстовый редактор для дальнейшего заполнения протокола. ![](p1.png) Файл Pr0.py(в каталоге ТЕМА2) будет нести в себе все команды и их вывод данной лаборатрной работы. ## 2.Простые объекты Операции присваивания представлены в следующем примере: ```py >>> f1=16; f2=3 >>> f1,f2 (16, 3) >>> f1;f2 16 3 ``` Здесь f1,f2 - переменные, несущие в себе значения, которые задаются после знака "=". Если мы захотим узнать, какое значение имеет определённая переменная, это можно провести через знак ","(в одной строке) или ";"(каждая следующая строка), в зависимости от того, как мы собираемся разделять полученные значения. Следующая функция позволяет узнать какие объекты на данный момент существуют в среде: ```py >>> dir() ['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'f1', 'f2', 'os'] ``` Помимо встроенных в среду объектов, также можно заметить нами созданные: f1 и f2. Добавив аргумент, мы обращаемся к конкретному объекту: ```py >>> 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'] ``` Функцией type() для этого же объекта определим классовую принадлежность: ```py >>> type(f1) ``` В данном случае переменная f1 и вправду несёт в себе целое число "16". Если нам необходимо удалить объект из оперативной памяти следует использовать инструкцию del. Попробуем удалить f1 и f2: ```py >>> del f1 >>> del f2 >>> dir(f1) Traceback (most recent call last): File "", line 1, in dir(f1) NameError: name 'f1' is not defined >>> dir() ['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'os'] ``` Заметим, что эти объекты были удалены, а при прямом указания аргумента в инструкции dir() выдаёт ошибку. ## 3.Именования объектов в среде. Правильные: ```py >>> gg1=1.6; gg1 1.6 >>> hh1='Строка'; hh1 'Строка' ``` Неправильные: ```py >>> 73sr=3; 73sr SyntaxError: invalid syntax >>> and=7; and SyntaxError: invalid syntax ``` ## 4.Список ключевых слов. ```py >>> import keyword >>> 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'] >>> key=keyword.kwlist >>> key ['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'] >>> type(key) ``` ## 5.Список встроенных идентификаторов. ```py >>> 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'] ``` Изучим некоторые функции из данного списка. Для этого также будем обращаться к помощи по следующей инструкции(для остальных функций по такому же принципу, можно посмотреть в протоколе): # Модуль числа ```py >>> help(abs) Help on built-in function abs in module builtins: abs(x, /) Return the absolute value of the argument. >>> abs(13-40) 27 ``` # Количество элементов в объекте ```py >>> len("2932") 4 >>> len(key) 36 ``` # Максимальное и минимальное значение ```py >>> max(0,19,20,-2,200,-1012,99,134) 200 >>> max("в", "з", "щ", "я") 'я' #По алфавиту позже остальных букв в данном перечне >>> min(0,19,20,-2,200,-1012,99,134) -1012 >>> min("в", "з", "щ", "я") 'в' #По алфавиту раньше остальных букв в данном перечне ``` # Возведение числа в степень ```py >>> pow(2,3) 8 >>> pow(2,3,3) #3 аргумент - mod, вычисляет остаток в результате деления на mod 2 >>> pow(4,-3) 0.015625 ``` # Округление ```py >>> round(123.456) 123 >>> round(123.456,1) 123.5 >>> round(123.456,-1) 120.0 ``` # Сортировка по возрастанию и убыванию ```py >>> n=[-10,8,2,-3,5.5] >>> sorted(n) [-10, -3, 2, 5.5, 8] >>> sorted(n,reverse=True) [8, 5.5, 2, -3, -10] >>> w=["apple","banana","kiwi","strawberry"] >>> sorted(w) ['apple', 'banana', 'kiwi', 'strawberry'] >>> sorted(w,reverse=True) ['strawberry', 'kiwi', 'banana', 'apple'] ``` # Суммирование ```py >>> sum(n) 2.5 >>> sum(n,10) #Задаём начальное значение(по умолчанию 0, здесь - 10) 12.5 >>> sum([x*2 for x in n]) #Каждое значение берётся в квадрат и суммируется с последующим 5.0 ``` # Объединение нескольких объектов ```py >>> list1=[1,2,3];list2=['a','b','c'] >>> z=zip(list1,list2) >>> list(z) [(1, 'a'), (2, 'b'), (3, 'c')] >>> list3=[4,5,6] >>> list(zip(list1,list2,list3)) [(1, 'a', 4), (2, 'b', 5), (3, 'c', 6)] ``` ## 6.Регистр ```py >>> Gg1=45 >>> gg1 1.6 ``` Если мы введём новую переменную, отличающуюся лишь регистром, она будет считаться отдельной. Gg1 и gg1 - разные переменные с разными значениями. ## 7.Базовые типы объектов # 7.1.Логический тип. ```py >>> bb1=True; bb2=False >>> bb1;bb2 True False >>> type(bb1) ``` # 7.2.Другие простые типы ```py >>> ii1=-1234567890;ii1;type(ii1) -1234567890 >>> ff1=-8.9876e-12;ff1;type(ff1) -8.9876e-12 >>> dv1=0b1101010;dv1;type(dv1) 106 >>> vsm1=0o52765;vsm1;type(vsm1) 22005 >>> shest1=0x7109af6;shest1;type(shest1) 118528758 >>> cc1=2-3j;cc1;type(cc1) (2-3j) >>> a=3.67;b=-0.45;cc2=complex(a,b);cc2;type(cc2) (3.67-0.45j) ``` # 7.3.Строка символов ```py >>> ss1='Это - строка символов';ss1 'Это - строка символов' >>> ss1="Это - строка символов";ss1 'Это - строка символов' >>> ss1a="Это - \" строка символов \", \n \t выводимая на двух сторонах"; print(ss1a) Это - " строка символов ", выводимая на двух сторонах >>> ss1b='Меня зовут: \n Кузьменко Е.А.'; print(ss1b) Меня зовут: Кузьменко Е.А. >>> mnogo="""Нетрудно заметить, что в результате операции над числами разных типов получается число, имеющее более сложный тип из тех, которые учавствуют в операции."""; print(mnogo) Нетрудно заметить, что в результате операции над числами разных типов получается число, имеющее более сложный тип из тех, которые учавствуют в операции. >>> ss1 'Это - строка символов' >>> ss1[0] 'Э' >>> ss1[8] 'р' >>> ss1[-2] 'о' >>> ss1[6:9] 'стр' >>> ss1[13:] 'символов' >>> ss1[:13] 'Это - строка ' >>> ss1[5:-8] ' строка ' >>> ss1[3:17:2] ' тоасм' >>> 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 'Это = строка символов' # Примеры с ss1b >>> print(ss1b) Меня зовут: Кузьменко Е.А. >>> ss1b 'Меня зовут: \n Кузьменко Е.А.' >>> ss1b[0] 'М' >>> ss1b[14:] 'Кузьменко Е.А.' >>> ss1b[0:15:3] 'Мяот\n' >>> ss1b1=ss1b[:10]+' : \n'+ss1b[14:];print(ss1b1) Меня зовут : Кузьменко Е.А. >>> x1=6-24j;x1;type(x1) (6-24j) >>> x2=0.14e-13;x2;type(x2) 1.4e-14 >>> x3=0b0101;x3;type(x3) 5 >>> x4=True;x4;type(x4) True >>> x5=None;x5;type(x5) ``` ## 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] >>> spis1[-1] (5-9j) >>> stup[-8::2] #Начииная от 8 элемента с конца и заканчивая последним значением с шагом 2 [0, 1, 1, 1] >>> spis1[1]='Список';spis1 [111, 'Список', (5-9j)] >>> len(spis1) 3 # Методы добавления и удаления объекта >>> dir() ['Gg1', '__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'a', 'b', 'bb1', 'bb2', 'builtins', 'cc1', 'cc2', 'dv1', 'f', 'ff1', 'gg1', 'hh1', 'ii1', 'key', 'keyword', 'list1', 'list2', 'list3', 'mnogo', 'n', 'os', 'rating', 'shest1', 'spis', 'spis1', 'ss1', 'ss1a', 'ss1b', 'ss1b1', 'students', 'stup', 'vsm1', 'w', 'x1', 'x2', 'x3', 'x4', 'x5', 'z', 'z1'] >>> 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+['New item'];spis1 #Только отображается! [111, 'Список', (5-9j), 'New item', 'New item'] [111, 'Список', (5-9j), 'New item'] >>> spis1.pop(1) 'Список' >>> spis1 [111, (5-9j), 'New item'] >>> spis1.append(ss1b);print(spis1) [111, (5-9j), 'New item', 'Меня зовут: \n Кузьменко Е.А.'] # Другие методы >>> spis1.insert(3,'Новый объект');spis1 #Вставляет объект на указанную позицию [111, (5-9j), 'New item', 'Новый объект', 'Меня зовут: \n Кузьменко Е.А.'] >>> spis1.remove('New item');spis1 #Удаляет конкретный объект [111, (5-9j), 'Новый объект', 'Меня зовут: \n Кузьменко Е.А.'] >>> spis2=['aa',123,'bb'];spis2 ['aa', 123, 'bb'] >>> spis1.extend(spis2);spis1 #Добавляет объекты в конец списка [111, (5-9j), 'Новый объект', 'Меня зовут: \n Кузьменко Е.А.', 'aa', 123, 'bb'] >>> spis2.clear();spis2 #Очищает список [] >>> spis3=[-9,2,5,0,10,-11];spis3.sort();spis3 #Сортирует по возрастанию [-11, -9, 0, 2, 5, 10] >>> spis3.sort(reverse=True);spis3 #Сортирует по убыванию [10, 5, 2, 0, -9, -11] >>> spis1.reverse();spis1 #Выписывает список в обратном порядке ['bb', 123, 'aa', 'Меня зовут: \n Кузьменко Е.А.', 'Новый объект', (5-9j), 111] >>> copy1=spis1.copy();copy2=spis3.copy();print(copy1,copy2) #Копирует список ['bb', 123, 'aa', 'Меня зовут: \n Кузьменко Е.А.', 'Новый объект', (5-9j), 111] [10, 5, 2, 0, -9, -11] >>> spis4=[1,1,0,2,4,5,5,1];spis4.count(1) #Считает сколько раз конкретный элемент вошёл в список 3 >>> spis4.index(5) #Находит индекс первого вхождения "5" 5 # Вложенные списки >>> spis2=[spis1,[4,5,6,7]];spis2 [['bb', 123, 'aa', 'Меня зовут: \n Кузьменко Е.А.', 'Новый объект', (5-9j), 111], [4, 5, 6, 7]] >>> spis2[0][1] #Обращение к элементу первого списка(т.к. "0") 123 >>> spis2[0][1]=78;spis2;spis1 [['bb', 78, 'aa', 'Меня зовут: \n Кузьменко Е.А.', 'Новый объект', (5-9j), 111], [4, 5, 6, 7]] ['bb', 78, 'aa', 'Меня зовут: \n Кузьменко Е.А.', 'Новый объект', (5-9j), 111] ``` При изменении spis2[0][1], мы поменяли второй элемент в самом списке spis1, так как заданный spis2[0] и есть spis1. ```py >>> spis0=[123, 'ice cream', False, spis2];spis0 [123, 'ice cream', False, [['bb', 78, 'aa', 'Меня зовут: \n Кузьменко Е.А.', 'Новый объект', (5-9j), 111], [4, 5, 6, 7]]] ``` # 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, 'Меня зовут: \n Кузьменко Е.А.') >>> kort2=kort1[:2]+kort1[3:];kort2 (222, 'Kortezh', 1, 2, 'Меня зовут: \n Кузьменко Е.А.') >>> kort1.index(2);kort1 #Первое появление двойки 4 >>> kort1.count(222) 1 >>> kort1[2]=90;kort1 #Нельзя изменить кортеж Traceback (most recent call last): File "", line 1, in kort1[2]=90;kort1 TypeError: 'tuple' object does not support item assignment >>> kort3=(16,'boo',[1,2,"aa"],(2,"bb",2));kort3 (16, 'boo', [1, 2, 'aa'], (2, 'bb', 2)) ``` # 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'};dic2 {1: 'mean', 2: 'standart deviation', 3: 'correlation'} >>> dic3={'statics':dic2,'POAS':['base','elementary','programming']};dic3 {'statics': {1: 'mean', 2: 'standart deviation', 3: 'correlation'}, 'POAS': ['base', 'elementary', 'programming']} >>> dic4=dict([(1,['A','B','C']),(2,[4,5]),('Q','Prim'),('Stroka',ss1b)]);dic4 {1: ['A', 'B', 'C'], 2: [4, 5], 'Q': 'Prim', 'Stroka': 'Меня зовут: \n Кузьменко Е.А.'} >>> dic5=dict(zip(['A','B','C','Stroka'],[16,-3,9,ss1b]));dic5 #Объединение ключей и значений {'A': 16, 'B': -3, 'C': 9, 'Stroka': 'Меня зовут: \n Кузьменко Е.А.'} >>> kort11=(2,6,'sa',True,False,12,1);kort11 (2, 6, 'sa', True, False, 12, 1) >>> spis11=[2,'oo','bb',3,5];spis11 [2, 'oo', 'bb', 3, 5] >>> dic11=dict(zip(kort11,spis11));dic11 {2: 2, 6: 'oo', 'sa': 'bb', True: 3, False: 5} ``` В данном случае кортеж - 7 элементов, список - 5 элементов. Однако создаваемый словарь подстроится под наименьшее количество элементов, пока в обоих перечнях присутствуют пары без повторов. ```py #Пример словаря >>> 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 {'двигатель', 'микропроцессор', 'реле', 'линия связи', 'датчик'} >>> mnoz1.remove('линия связи');mnoz1 {'двигатель', 'микропроцессор', 'реле', 'датчик'} >>> mnoz2={4.12,'rr',True,True,2,2,3.2,'rr','rr',(1,2)};mnoz2 {True, 2, 3.2, (1, 2), 4.12, 'rr'} >>> len(mnoz2) 6 >>> 2 in mnoz2 True >>> 3 in mnoz2 False >>> mnoz2.add('oo');mnoz2 {True, 2, 3.2, (1, 2), 4.12, 'oo', 'rr'} >>> mnoz2.remove(3.2);mnoz2 {True, 2, (1, 2), 4.12, 'oo', 'rr'} ``` # 9.Завершение работы со средой.