diff --git a/TEMA2/report.md b/TEMA2/report.md new file mode 100644 index 0000000..9e69b55 --- /dev/null +++ b/TEMA2/report.md @@ -0,0 +1,361 @@ +# Отчет по теме 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 Завершение работы. diff --git a/TEMA2/test.md b/TEMA2/test.md new file mode 100644 index 0000000..a29050a --- /dev/null +++ b/TEMA2/test.md @@ -0,0 +1,15 @@ +# Индивидуальное контрольное задание по теме 1 + +Коломейцев Дмитрий, А-02-23 + +## Вопрос + +Как можно запустить на выполнение программу, исходный код которой находится в текстовом файле ABC.txt? + +## Ответ + +В IDLE открыть файл "ABC.txt" в новом окне, затем запустить с помощью Run Module. Код запускается исправно даже из .txt + +![alt text]({F7D7B2E4-76E6-4F38-9C43-470D24B73207}.png) + +![alt text]({B972A96F-678A-40AB-BAFF-18C9F80851E2}.png) \ No newline at end of file