diff --git a/TEMA2/report.md b/TEMA2/report.md new file mode 100644 index 0000000..d0d1f0b --- /dev/null +++ b/TEMA2/report.md @@ -0,0 +1,531 @@ +# Отчет по теме 2 Основы программирования Python +### Бушманов Артём Сергеевич, А-01-23. +### 1. Запуск оболочки IDLE +Установка рабочего каталога. +```Python +import os +os.chdir('/Users/ArtyomBushmanov/python-labs/TEMA2') +``` +### 2.1 Изучение простых обьектов +```python +>>> f1=16 +>>> f2=3 +>>> f1,f2 +(16, 3) +>>> f1;f2 +16 +3 +``` + +```python +>>> 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__', '__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(f2) + + +>>> del f1,f2 +>>> dir() +['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'os'] +``` + +### 3. Изучение правил именования объектов в Python +Правила именования: +-  имена должны состоять из латинских букв, цифр и символов подчеркивания; +-  имена должны начинаться с латинской буквы (иногда могут начинаться с символа подчеркивания, но это – особый вид переменных); +-  имена не должны совпадать с ключевыми словами и встроенными идентификаторами языка Python; +-  большие и малые буквы в именах различаются (имена – чувствительные к регистру)! +С учетом этих правил в командном окне IDLE выполним следующие операции. +```python +>>> gg1=1.6 +>>> hh1='Строка' +>>> 73sr=3 +SyntaxError: invalid decimal literal +>>> and=7 +SyntaxError: invalid syntax +``` +### 4. Вывод списка ключевых слов с помощью инструкции. +```python +>>> 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'] +``` +### 5. Вывод списка встроенных идентификаторов с помощью инструкций + ```python + >>> 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', '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.1 Изучение функций (abs, len, max, min, pow, round, sorted, sum, zip) +#### abs() +```python +>>> abs(-7) +7 +``` + Возвращает модуль числа +#### len() +```python +>>> len([1, 2, 3]) +3 +``` + Возвращает количество элементов в объекте (например, в списке) +#### max() +```python +>>> max(3, 5, 2) +5 +``` + Возвращает максимальное значение +#### min() +```python +>>> abs(-7) +7 +``` +Возвращает модуль числа +#### pow() +```python +>>> pow(2, 3) +8 +``` + Возводит число 2 в 3ью степень = 8 +#### round() +```python +>>> round(3.1415926, 2) +3.14 +``` +Округляет число до заданного количества знаков после запятой +#### sorted() +```python +>>> sorted([3, 1, 2]) +[1, 2, 3] +``` + Возвращает отсортированный список +#### sum() +```python +>>> sum([1, 2, 3]) +6 +``` + Возвращает сумму всех элементов в последовательности +#### zip() +```python +>>> list(zip([1, 2, 3], ['a', 'b', 'c'])) +[(1, 'a'), (2, 'b'), (3, 'c')] +``` +Создаёт пары элементов из нескольких последовательностей +### 6. Малые и большие буквы различаются +```python +>>> Gg1=45 +>>> gg1, Gg1 +(1.6, 45) +``` +### 7. Изучение базовых типов объектов +Базовые типы объектов: +#### Логический (**bool**) +```python +>>> bb1=True +>>> bb2=False +>>> bb1;bb2 +True +False +>>> type(bb1) + +``` +#### Целый (**int**) +```python +>>> ii1=-1234567890 +``` +#### Вещественный (**float**) +```python +>>> a = 3.67 +>>> b = -0.45 +>>> ff1=-8.9876e-12  #экспоненциальная форма записи вещественного числа +``` +#### Комплексный (**complex**) +```python +>>> cc1=2-3j +>>> z = -1j +>>> cc2=complex(a,b)  #Создается комплексное число +>>> cc2 +(3.67-0.45j) +``` +#### Строка символов (**str**) +```python +>>> ss1 = 'Это - строка символов' +>>> ss1 = "Это - строка символов" +>>> ss1a="Это - \" строка символов \", \n \t выводимая на двух строках" +>>> print(ss1a) +Это - " строка символов ", + выводимая на двух строках + +>>> ss1b= 'Меня зовут: \n <Подольский НК>' +>>> print(ss1b) +Меня зовут: + <Подольский НК> +``` + +```python +>>> mnogo = """Нетрудно заметить , что в результате операции над числами разных типов получается число, имеющее более сложный тип из тех, которые участвуют в операции.""" +>>> print(mnogo) +Нетрудно заметить , что в результате операции +над числами разных типов получается число, +имеющее более сложный тип из тех, которые участвуют в операции. +``` + +```python +>>> ss1[0] +'Э' +>>> ss1[8] +'р' +>>> ss1[-2] +'о' +>>> ss1[6:9] #Это часть строки – символы с 6-го индекса по 8-й (9-й не включается!) +'стр' +>>> ss1[13:] +'символов' +>>> ss1[:13] +'Это - строка ' +>>> ss1[5:-8] +' строка ' +>>> ss1[3:17:2] +' тоасм' +>>> ss1[17:3:-2] +'омсаот ' +>>> ss1[-4:3:-2] +'омсаот ' +``` + +```python +>>> ss1[4]='=' +Traceback (most recent call last): + File "", line 1, in + ss1[4]='=' # Будет диагностика! +TypeError: 'str' object does not support item assignment +``` +Будет диагностика! + +```python +>>> ss1=ss1[:4]+'='+ss1[5:] +>>> ss1 +'Это = строка символов' +``` + +```python +>>> ss1b[3:10] +'я зовут' +>>> ss1b[5:15] +'зовут: \n <' +>>> ss1b[2:-5:2] +'н оу:\n<ооьк' +``` +### 8. Типы объектов (списки (list) , кортежи (tuple), словари (dict), множества (set)) +### 8.1 Списки + Список – это последовательность:  упорядоченная по местоположению коллекция объектов произвольных типов, размер которых практически не ограничен. В отличие от символьных строк, списки являются изменяемыми последовательностями, т.е. их элементы могут изменяться с помощью операций присваивания. + +```python +>>> spis1=[111,'Spisok',5-9j] +>>> spis1 +[111, 'Spisok', (5-9j)] +``` + +```python +>>> stup=[0,0,1,1,1,1,1,1,1] +>>> stup +[0, 0, 1, 1, 1, 1, 1, 1, 1] +``` + +```python +>>> spis=[1,2,3,4, + +      5,6,7, + +      8,9,10] +>>> spis +[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] +``` + +```python +>>> spis1[-1] +(5-9j) + +>>> stup[-8::2] +[0, 1, 1, 1] + +>>> spis1[1]='Список' +>>> spis1 +[111, 'Список', (5-9j)] +``` + +```python +>>> len(spis1) +3 +``` + +```python +>>> help(spis1.append) +Help on built-in function append: + +append(object, /) method of builtins.list instance + Append object to the end of the list. +``` + +```python +>>> spis1.append('New item') +>>> spis1 +[111, 'Список', (5-9j), 'New item'] +>>> spis1+['New item'] +[111, 'Список', (5-9j), 'New item', 'New item'] +>>>spis1 +[111, 'Список', (5-9j), 'New item'] +``` + +#### Удаление элемента списка +```python +>>> spis1.pop(1) #Из списка удален элемент с индексом 1 +'Список' +>>> spis1 +[111, (5-9j), 'New item'] +``` + +#### insert +```python +>>> lst = [1, 2, 3] +>>> lst.insert(1, 100) +[1, 100, 2, 3] +``` +#### remove +```python +>>> lst = [1, 2, 3] +>>> lst.remove(2) +[1, 3] +``` +#### extend +```python +>>> lst = [1, 2] +>>> lst.extend([3, 4]) +[1, 2, 3, 4] +``` +#### clear +```python +>>> lst = [1, 2, 3] +>>> lst.clear() +[] +``` +#### sort +```python +>>> lst = [3, 1, 2] +>>> lst.sort() +[1, 2, 3] +``` +#### reverse +```python +>>> lst = [1, 2, 3] +>>> lst.reverse() +[3, 2, 1] +``` +#### copy +```python +>>> lst = [1, 2, 3] +>>> new_lst = lst.copy() +[1, 2, 3] +``` +#### count +```python +>>> lst = [1, 2, 2, 3] +>>> lst.count(2) +2 +``` +#### index +```python +>>> lst = [10, 20, 30] +>>> lst.index(20) +1 +``` + +#### Вложенный список +```python +>>> spis2=[spis1,[4,5,6,7]] #здесь элементами являются два спискa +>>> spis2 +[[111, (5-9j), 'New item'], [4, 5, 6, 7]] +``` + +```python +>>> spis2[0][1] #обращение к элементу списка spis1 +(5-9j) +>>> spis2[0][1]=78 #Убедитесь, что значение элемента заменено на 78 +>>> spis1 +[111, 78, 'New item'] +``` +При создании spis2 = [spis1, [4,5,6,7]] первый элемент списка spis2 не копирует spis1, а хранит ссылку на него. +Поэтому когда мы изменили элемент spis2[0][1] = 78, это изменение произошло непосредственно в объекте spis1. +В результате сам spis1 изменился, и его второй элемент 'Список' был заменён на 78. + +```python +>>> my_list = [42, "Привет, мир!", True, [1, 2, 3]] +>>> print(my_list) +[42, 'Привет, мир!', True, [1, 2, 3]] +``` + +### 8.2 Объект - кортеж + Объект-кортеж похож на список, но его нельзя изменить – кортежи являются последовательностями, как списки, но они являются неизменяемыми, как строки. В отличие от списка литерал кортежа заключается в круглые, а не в квадратные скобки. Кортежи также поддер­живают включение в них объектов различных типов и операции, типич­ные для последовательностей. + + ```python + >>> 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 <Подольский НК>') + ``` + +#### Важные методы кортежа +##### Определение индекса заданного элемента: +``` python +  >>> kort1.index(2) +  4 +``` + +##### Подсчет числа вхождений заданного элемента в кортеже: +``` python +>>> kort1.count(222) +1 +``` + +##### Операция замены элемента кортежа +``` python +>>> kort1[2]=90   +Traceback (most recent call last): + File "", line 1, in + kort1[2]=90 +TypeError: 'tuple' object does not support item assignment +``` + +#### Создание объекта-кортежа с элементами разных типов: +``` python +>>> my_tuple = (99, "Python", [1, 2, 3], (True, False)) +>>> print(my_tuple) +(99, 'Python', [1, 2, 3], (True, False)) +``` + +### 8.3 Объект - словарь +``` python +>>> dic1={'Saratov':145, 'Orel':56, 'Vologda':45} +>>> dic1 +{'Saratov': 145, 'Orel': 56, 'Vologda': 45} +``` + +``` python +>>> dic1['Orel'] +56 +``` + +``` python +>>> dic1['Pskov']=78 +>>> dic1 +{'Saratov': 145, 'Orel': 56, 'Vologda': 45, 'Pskov': 78} +``` + +```python +>>> sorted(dic1.keys()) +['Orel', 'Pskov', 'Saratov', 'Vologda'] + +>>> sorted(dic1.values()) +[45, 56, 78, 145] +``` + +##### Создадим словарь +``` python +>>> 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': 'Меня зовут: \n <Подольский НК>'} + +>>> dic5=dict(zip(['A','B','C','Stroka'],[16,-3,9,ss1b])) +>>> dic5 +{'A': 16, 'B': -3, 'C': 9, 'Stroka': 'Меня зовут: \n <Подольский НК>'} +``` + +```python +# кортеж с 7 элементами +>>> keys_tuple = ('a', 'b', 'c', 'd', 'e', 'f', 'g') + +# список с 5 элементами +>>> values_list = [1, 2, 3, 4, 5] + +>>> my_dict = dict(zip(keys_tuple, values_list)) +>>> print(my_dict) +{'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5} + +>>> len(my_dict) +5 +``` +- У нас есть **7 ключей** и **5 значений**. +- Функция zip работает до тех пор, пока хватает элементов в самой короткой последовательности. +- Так как в списке только 5 элементов, то сформировалось 5 пар «ключ–значение». +### 8.4 Объект-множество – это неупорядоченная совокупность неповторяющихся элементов +```python + +>>> mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'} + +>>> mnoz1 + +{'датчик', 'линия связи', 'двигатель', 'микропроцессор'} + +>>> len(mnoz1) + +4 + +>>> 'датчик' in mnoz1 + +True + +>>> mnoz1.add('реле') + +>>> mnoz1 + +{'двигатель', 'датчик', 'микропроцессор', 'реле', 'линия связи'} + +>>> mnoz1.remove('линия связи') + +>>> mnoz1 + +{'двигатель', 'датчик', 'микропроцессор', 'реле'} + +Самостоятельно придумал объект-множество с элементами разных +``` python +>>> mnoz2 = {1, 'число',(15, 30, 45), 3.14} +>>> mnoz2 +{1, (15, 30, 45), 3.14, 'число'} +>>> len(mnoz2)  # количество элементов +4 +>>> 'число' in mnoz2  +True +>>> mnoz2.add(False) +>>> mnoz2 +>>> {False, 1, 3.14, 'число', (15, 30, 45)} +>>> mnoz2.remove(1) +>>> mnoz2 + +{False, 3.14, 'число', (15, 30, 45)} +``` +### 1.16 Завершаем работу со средой. +Выбираем File и exit. +### 1.17 Контрольные вопросы. diff --git a/TEMA2/task.md b/TEMA2/task.md new file mode 100644 index 0000000..e3b5204 --- /dev/null +++ b/TEMA2/task.md @@ -0,0 +1,75 @@ +# Общее контрольное задание по теме 2 +Бушманов Артём Сергеевич, А-01-23 +## Задание +Реализовать, записать в текстовый файл и проанализировать результаты последовательности инструкций, выполняющих следующие действия: +·      Создать переменную с именем **familia** и со значением - символьной строкой – своей фамилией в латинской транскрипции. +·      Создать переменную со значением, совпадающим с первой буквой из **familia**. +·      Создать переменную с именем **sp****_****kw** со значением – списком всей ключевых слов языка Python. +·      Удалите из списка **sp****_****kw** значение **'nonlocal'**. Выводом списка в командном окне IDLE убедитесь, что это значение удалено из списка. +·      Создайте кортеж **kort****_****nam** с именами: вашим и еще 3-х студентов из вашей группы. Напишите инструкцию, позволяющую убедиться, что тип переменной – это **tuple**. +·      Напишите инструкцию, добавляющую в **kort****_****nam** имена еще двух студентов. +·      Напишите инструкцию, позволяющую определить, сколько раз в кортеже присутствуют студенты с именем «Дима». +·      Создайте словарь **dict****_****bas**, в котором ключами являются русские названия типов переменных, использованных в предыдущих операторах, а значениями – ранее созданные переменные, соответствующие этим типам. +## Решение + +### 1. Создаю переменную familia + +```python +>>> familia = 'Bushmanov' +``` + +### 2. Создаю переменную которая = первой букве familia + +```python +>>> fam1=familia[0] +>>> fam1 +'B' +``` + +### 3. Создаю переменную с именем sp_kw, значение – списк всех ключевых слов Python. + +```python +>>> import keyword +>>> sp_kw = keyword.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'] +``` + +### 4. Удаляю из списка sp_kw значение 'nonlocal', затем убедился, что это значение удалено из списка. + +```python +>>> 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'] +``` + +### 5. Создаю кортеж kort_nam с моим и еще 3-х студентов из группы именами. Проверяю, что тип переменной – это tuple. + +```python +>>> kort_nam = ("Artyom", "Dmitriy", "Maksim", "Denis") +>>> type(kort_nam) + +``` + +### 6. Добавляю в kort_nam имена двух студентов. + +```python +>>> kort_nam += ("Vanya", "Pasha") +>>> kort_nam +('Nikita', 'Vadim', 'Artem', 'Dima', 'Vanya', 'Pasha') +``` + +### 7. Определяю, сколько раз в кортеже присутствуют студенты с именем «Vanya». + +```python +>>> kort_nam.count("Vanya") +1 +``` + +### 8. Создаю словарь dict_bas, в котором ключами являются русские названия типов переменных, использованных в предыдущих операторах, а значениями – ранее созданные переменные, соответствующие этим типам. + +```python +>>> dict_bas = {"строка": familia, "символ": fam1, "список": sp_kw, "кортеж": kort_nam,} +>>> dict_bas +{'строка': 'Podolskiy', 'символ': 'P', 'список': ['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'], 'кортеж': ('Nikita', 'Vadim', 'Artem', 'Dima', 'Vanya', 'Pasha')} +``` \ No newline at end of file