# Отчёт по теме 2 Соловьёва Екатерина, А-01-23 ## 1. Начало работы с оболочкой IDLE. Установила рабочий каталог, создала текстовый редактор с комментарием и сохранила в рабочий каталог. ```py import os os.chdir('C:\\Users\Ekaterina\\OneDrive\\Desktop\\Solovyova\\python-labs\\TEMA2') ``` ## 2. Изучение простых конструкций языка Python. ```py f1=16; f2=3 #Операция присваивания f1,f2 или f1;f2 #Чтение переменных (можно записать через запятую или точку с запятой) dir() #просмтор всех объектов dir(f1) #просмтор атрибутов конкретного объекта type(f2) #определение классовой принадлежности del f1,f2 #удаление объектов ``` ## 3. Допустимые и недопустимые именования объектов ```py gg1=1.6 #значение в виде вещественного числа hh1='Строка' #значение в виде символьной строки 73sr=3 #неправильное имя – начинается с цифры - будет диагностика! and=7 #недопустимое имя – совпадает с ключевым словом - будет диагностика! ``` ## 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'] keywords_list = keyword.kwlist #сохранила список в переменной ``` ## 5.1 Просмотр встроенных идентификаторов ```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'] ``` ## 5.2 Изучение встроенных функций ```py help(abs),help(len), help(max), help(min), help(pow), help(round), help(sorted), help(sum), help(zip) ``` abs - модуль от числа max/min - вывод максимального/минимального числа для либо списка либо для нескольких перечисленных переменных len - выводит кол-во объектов в контейнере pow - возводит число в степень round - округляет число sum - дает сумму всех элементов в контейнере sorted - сортирует по возрастанию элементы в контейнере zip - "сшивает" значения из одной последовательности значений с соответствующими значениями из другой Попробую некоторые функции в действии: ```py print(pow(2, 3)) #возводит 2 в степень 3 8 print(round(3.14159, 2)) #округляет до 2 знаков после запятой, так как я указала 3.14 names = ["Анна", "Борис", "Виктор"] ages = [25, 30, 35] zipped = list(zip(names, ages)) print(zipped) [('Анна', 25), ('Борис', 30), ('Виктор', 35)] ``` ## 6. Значимость регистра При присваивании имен переменным важен также регистр букв. ```py Gg1=45 Gg1 45 gg1 1.6 ``` ## 7.Изучение базовых типов объектов ## 7.1 Логический тип ```py bb1=True; bb2=False bb1;bb2 True False type(bb1) ``` ## 7.2. Другие простые типы ```py ii1=-1234567890 ff1=-8.9876e-12 dv1=0b1101010 type(dv1) vsm1=0o52765 shest1=0x7109af6 #два способа создания комплексных чисел: cc1=2-3j a=3.67; b=-0.45 cc2=complex(a,b) ``` ## 7.3. Строка символов ```py ss1a="Это - \" строка символов \", \n \t выводимая на двух строках" print(ss1a) Это - " строка символов ", выводимая на двух строках ss1b= 'Меня зовут: \n Соловьёва Е. Д.' print(ss1b) Меня зовут: Соловьёва Е. Д. #Многострочные строки можно задавать в виде значения объекта с использованием тройных кавычек, например, mnogo="""Нетрудно заметить , что в результате операции над числами разных типов получается число, имеющее более сложный тип из тех, которые участвуют в операции.""" print(mnogo) Нетрудно заметить , что в результате операции над числами разных типов получается число, имеющее более сложный тип из тех, которые участвуют в операции. ``` Можно обращаться к частям строки символов с использованием индексов символов по их порядку в строке. При этом надо учитывать, что нумерация символов начинается с 0. Например, ```py 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]='=' # Будет диагностика! #Однако, можно это сделать по-другому, переопределив строку: ss1=ss1[:4]+'='+ss1[5:] ``` Самостоятельно сделала некоторые срезы ```py ss1b[0:23] 'Меня зовут: \n Соловьёва' ss1b[14:23:1] 'Соловьёва' ss1b[3:10] 'я зовут' ss1b[14:23:2] 'Слвёа' ``` ## 8. Сложные типы объектов. ## 8.1 Список ```py spis1=[111,'Spisok',5-9j] #Пример списка с 3 элементами разных типов 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) #число элементов в списке 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.append(ss1b) print(spis1) [111, (5-9j), 'New item', 'Меня зовут: \n Соловьёва Е. Д.'] ``` 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 spisok = [1, 2, 4, 5] spisok.insert(2, 3) # Вставить 3 на позицию с индексом 2 print(spisok) [1, 2, 3, 4, 5] spisok = [1, 2, 3] spisok.extend([4, 5, 6]) # Добавить элементы другого списка print(spisok) [1, 2, 3, 4, 5, 6] ``` Списки могут быть вложенными: ```py spis2=[spis1,[4,5,6,7]] spis2[0][1] (5-9j) spis2[0][1]=78 spis1 [111, 78, 'New item', 'Меня зовут: \n Соловьёва Е. Д.'] spis2 [[111, 78, 'New item', 'Меня зовут: \n Соловьёва Е. Д.'], [4, 5, 6, 7]] ``` spis1 изменился потому, что в Python списки передаются по ссылке, а не по значению. Когда мы изменяем элемент через spis2[0][1], мы фактически изменяем тот же объект, на который указывает spis1 Далее я создала список включающий объекты разных типов: число, строка, логическое значение, список: ```py spis3=[1,"one",True,spis1] spis3 [1, 'one', True, [111, 78, 'New item', 'Меня зовут: \n Соловьёва Е. Д.']] ``` ## 8.2. Кортеж Работа с кортежами - их нельзя изменять, но можно переопределять, таким образом внося изменения. ```py kort1=(222,'Kortezh',77+8j) kort1= kort1+(1,2) kort1= kort1+(ss1b,) kort2=kort1[:2]+kort1[3:] kort1.index(2) 4 kort1.count(222) 1 kort1[2]=90 Traceback (most recent call last): File "", line 1, in kort1[2]=90 TypeError: 'tuple' object does not support item assignment ``` Создам кортеж с элементами разных типов: число, строка, список, кортеж: ```py kortezh = (1,'one',[1, 1, 1],(1,2,3)) print(kortezh) (1, 'one', [1, 1, 1], (1, 2, 3)) ``` ## 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] 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])) dic5 {'A': 16, 'B': -3, 'C': 9, 'Stroka': 'Меня зовут: \n Соловьёва Е. Д.'} ``` Свой словарь состоит из 5 элементов, потому что мы "сшили" два контейнера, длина определилась по минимальному кол-ву. ```py testlist = ['pink','yellow','black','green','red'] testkort = ('P','Y','B','G','R','T','Q') dictest=dict(zip(testkort,testlist)) dictest {'P': 'pink', 'Y': 'yellow', 'B': 'black', 'G': 'green', 'R': 'red'} ``` ## 8.4. Множество Рассмотрим пример создания множества: ```py mnoz1 {'микропроцессор', 'двигатель', 'линия связи', 'датчик'} len(mnoz1) 4 'датчик' in mnoz1 True mnoz1.add('реле') mnoz1.remove('линия связи') mnoz1 {'микропроцессор', 'реле', 'двигатель', 'датчик'} ``` Создам свой пример множества ```py mnoz2={1,2,3,(222,'Kortezh',77+8j)} 222 in mnoz2 False Kortezh in mnoz2 Traceback (most recent call last): File "", line 1, in Kortezh in mnoz2 NameError: name 'Kortezh' is not defined (222, 'Kortezh', 77+8j) in mnoz2 True ``` ## Задание 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, в котором ключами являются русские названия типов переменных, использованных в предыдущих операторах, а значениями – ранее созданные переменные, соответствующие этим типам. # Общее контрольное задание по теме 2 ```py familia='Solovyova' familia 'Solovyova' bukva = familia[0] bukva 'S' sp_kw = kw.kwlist sp_kw ['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'] sp_kw.remove('nonlocal') sp_kw ['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', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield'] kort_nam = ('Екатерина', 'Фёдор', 'Елизавета','Никита') type(kort_nam) kort_nam = kort_nam + ("Дима", "Максим") kort_nam.count('Дима') 1 dict_bas = {'Строка': [familia,bukva], 'Список': sp_kw, 'Кортеж': kort_nam} dict_bas {'Строка': ['Solovyova', 'S'], 'Список': ['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', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield'], 'Кортеж': ('Екатерина', 'Фёдор', 'Елизавета', 'Никита', 'Дима', 'Максим')} ```