# Отчет по теме 2 Коломейцев Дмитрий, А-02-23 ## Тема 2. Базовые типы объектов ## 1-2. Изучение простых объектов Создали переменные f1 и f2, затем получили список атрибутов среды и каждой переменной отдельно командой dir(): ```py f1=16 f2=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'] dir(f2) ['__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(): ```py type(f1) type(f2) ``` Удалим переменные командой del var1, var2, ...: ```py del f1, f2 dir() ['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__'] ``` ## 3. Правила именования объектов в Python - Имена должны состоять из латинских букв, цифр и символов подчеркивания; - Имена должны начинаться с латинской буквы (иногда могут начинаться с символа подчеркивания, но это – особый вид переменных); - Имена не должны совпадать с ключевыми словами и встроенными идентификаторами языка Python; - Большие и малые буквы в именах различаются (имена – чувствительные к регистру)! ```py gg1=1.6 hh1='Строка' 73sr=3 SyntaxError: invalid decimal literal and=7 SyntaxError: invalid syntax ``` ## 4. Вывод списка ключевых слов Просмотрел список ключевых слов Python и записал их в переменную keyword_array. ```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'] keyword_array = keyword.kwlist keyword_array ['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. Вывод списка встроенных идентификаторов и изучение функций ```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'] ``` Изучил назначение математических функций с примерами: ```py # Модуль числа abs(-7) 7 # Длина объекта len("Привет, мир!") 11 # Максимально число max([5, 12, 3]) 12 # Минимальное число min(4, 9, 1) 1 # Степень числа pow(число, степень) pow(2, 5) 32 # Округление до n знаков после запятой round(3.14159, 2) 3.14 # Сортировка массива с параметрами (по возрастанию, по убыванию и т.д.) sorted([3, 1, 2, 5]) [1, 2, 3, 5] sorted([3, 1, 2, 5], reverse=True) [5, 3, 2, 1] # Сумма чисел sum([10, 20, 30]) 60 # Создаёт пары сопоставляя элементы 1 массива элементам 2 массива zip([1, 2, 3], ['a', 'b', 'c']) [(1, 'a'), (2, 'b'), (3, 'c')] ``` ## 6. Вывод переменных с разным регистром Вывел 2 переменные с одинаковым названием, но с разным регистром - значения разные: ```py Gg1=45 gg1 1.6 Gg1 45 ``` ## 7. Изучение простых базовых типов: bool, int, float, complex, str Логический тип хранит 2 типа значений: true и false. ### 7.1 Логический тип ```py bb1=True; bb2=False bb1;bb2 True False type(bb1) ``` ### 7.2 Другие простые типы ```py # Целый тип int ii1=-1234567890 ii1 -1234567890 # Вещественный тип float ff1=-8.9876e-12 ff1 -8.9876e-12 # Тип int, но двоичная запись dv1=0b1101010 dv1 106 # Тип int, но восьмеричная запись vsm1=0o52765 vsm1 22005 # Тип int, но шестнадцатеричная запись shest1=0x7109af6 shest1 118528758 # Тип complex комплексных чисел cc1=2-3j cc1 (2-3j) # Создание комплексной переменной из 2 int a=3.67; b=-0.45 a;b 3.67 -0.45 cc2=complex(a,b) cc2 (3.67-0.45j) ``` ### 7.3 Строковый тип (str) ```py ss1='Это - строка символов' ss1a="Это - \" строка символов \", \n \t выводимая на двух строках" mnogo="""Нетрудно заметить , что в результате операции над числами разных типов получается число, имеющее более сложный тип из тех, которые участвуют в операции.""" # Индексирование и срезы строк ss1[0] 'Э' ss1[8] 'р' ss1[-2] 'о' ss1[6:9] 'стр' ss1[13:] 'символов' ss1[:13] 'Это - строка ' ss1[5:-8] ' строка ' ss1[3:17:2] ' тоасм' ss1[17:3:-2] 'омсаот ' ss1b= 'Меня зовут: \n Коломейцев Д.А.' ss1b 'Меня зовут: \n Коломейцев Д.А.' ``` Изучил операции со строками: ```py # Конкатенация строк (соединение) ss1="Привет" ss14=" мир" ss15=ss1+ss14 print(ss1+'b') # конкатенация с символом ``` ## 8 Изучение составных типов данных: list, tuple, dict, set ### 8.1 Списки (list) Списки - упорядоченные коллекции объектов произвольных типов, которые можно изменять. ```py # Создание списков spis1=[111,"Spisok",5-9j] stup0=(0,0,1,1,1,1,1,1,1) spis1=[1,2,3,4, 5,6,7, 8,9,10] # Индексирование print(spis1[-1]) # последний элемент 10 print(stup0[-8:2]) # срез кортежа (0, 0) # Изменение списка spis1[1]=spis1 print(len(spis1)) # длина списка 10 # Методы списков spis1.append("New item") # добавление элемента print("New item" in spis1) # проверка наличия элемента True spis1.pop(1) # удаление элемента по индексу # Другие методы: # list.insert(i, x) - вставляет на i-тую позицию элемент x # list.remove(x) - удаляет первый элемент в списке со значением x # list.extend(L) - расширяет список list, добавляя в конец все элементы списка L ``` ### 8.2 Кортежи (tuple) Главное отличие кортежей от списков - их нельзя изменять после создания. ```py # Создание кортежей kort1=(222,"Kortezh",7+7.8j) print(kort1[1:2]) ('Kortezh',) # Методы кортежей # Все методы списков, не изменяющие список kort1.index(222) # поиск индекса элемента 0 kort1.count(222) # подсчет вхождений 1 ``` ### 8.3 Словари (dict) Словари в Python - неупорядоченные коллекции произвольных объектов с доступом по ключу. Каждому ключу сопоставляется значение. Ключами могут быть только неизменяемые типы. ```py # Создание словарей dic1={"Saratov":145, "Orel":56, "Vologda":45} print(dic1["Orel"]) 56 d = {} d {} d = {'dict': 1, 'dictionary': 2} d {'dict': 1, 'dictionary': 2} # Добавление элементов dic1["Pskov"]=78 print(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"} print(dic3["statistics"][2]) standart deviation # Другие методы: # dict.clear() - очищает словарь. # dict.copy() - возвращает копию словаря. # dict.get(key[, default]) - возвращает значение ключа, но если его нет, не бросает исключение, а возвращает default (по умолчанию None). # dict.items() - возвращает пары (ключ, значение). ``` ### 8.4 Множества (set) Объект-множество – это неупорядоченная совокупность неповторяющихся (уникальных) элементов. Эти элементы могут быть разных, но только неизменяемых типов (числа, строки, кортежи). ```py # Создание множеств mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'} mnoz1 {'двигатель', 'микропроцессор', 'линия связи', 'датчик'} len(mnoz1) 4 # Методы множеств 'датчик' in mnoz1 # проверка принадлежности True mnoz1.add('реле') # добавление элемента mnoz1 {'датчик', 'реле', 'двигатель', 'микропроцессор', 'линия связи'} mnoz1.remove('линия связи') # удаление элемента mnoz1 {'датчик', 'реле', 'двигатель', 'микропроцессор'} ``` ## 9 Завершение работы.