diff --git a/TEMA2/fbdfbf.py b/TEMA2/fbdfbf.py new file mode 100644 index 0000000..ad4b21f --- /dev/null +++ b/TEMA2/fbdfbf.py @@ -0,0 +1,306 @@ +Python 3.13.2 (tags/v3.13.2:4f8bb39, Feb 4 2025, 15:23:48) [MSC v.1942 64 bit (AMD64)] on win32 +Type "help", "copyright", "credits" or "license()" for more information. +f1=16; f2=3 +f1,f2 +(16, 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'] +type(f2) + +del f1,f2 +dir() +['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__'] +gg1=1.6 #значение в виде вещественного числа +hh1='Строка' #значение в виде символьной строки +73sr=3 #неправильное имя – начинается с цифры - будет диагностика! +SyntaxError: invalid decimal literal +and=7 #недопустимое имя – совпадает с ключевым словом - будет диагностика! +SyntaxError: invalid syntax +dir() +['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'gg1', 'hh1'] +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'] +kl = keyword.kwlist +kl +['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'] +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'] +abs(-10) +10 +len("len") +3 +max(1,25) +25 +min(1,25) +1 +pow(2,3) +8 +pow(2,3,3) +2 +round(2.85) +3 +>>> round(2.855,2) +2.85 +>>> round(2.856,2) +2.86 +>>> sorted(3,2,1) +Traceback (most recent call last): + File "", line 1, in + sorted(3,2,1) +TypeError: sorted expected 1 argument, got 3 +>>> sorted(321) +Traceback (most recent call last): + File "", line 1, in + sorted(321) +TypeError: 'int' object is not iterable +>>> sorted("c",'b','a') +Traceback (most recent call last): + File "", line 1, in + sorted("c",'b','a') +TypeError: sorted expected 1 argument, got 3 +>>> sorted("cba") +['a', 'b', 'c'] +>>> sum(5,2) +Traceback (most recent call last): + File "", line 1, in + sum(5,2) +TypeError: 'int' object is not iterable +>>> sum([3,7]) +10 +>>> list(zip([1,2,3],['a','b','c'])) +[(1, 'a'), (2, 'b'), (3, 'c')] +>>> Gg1 = 45 +>>> gg1 +1.6 +>>> dir() +['Gg1', '__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'builtins', 'gg1', 'hh1', 'keyword', 'kl'] +>>> Gg1 +45 +bb1=True; bb2=False +bb1;bb2 +True +False +type(bb1) + +ii1=-1234567890 +ff1=-8.9876e-12 #экспоненциальная форма записи вещественного числа +dv1=0b1101010 #Это – двоичное число. В объекте какого класса оно сохранено? +type(dv1) + +vsm1=0o52765 #Это – восьмеричное число +type(vsm1) + +shest1=0x7109af6 #Это – шестнадцатеричное число +type(shest1) + +cc1=2-3j +type(cc1) + +a=3.67; b=-0.45 +cc2=complex(a,b) #Создается комплексное число +ss1='Это - строка символов' +ss1 +'Это - строка символов' +ss1="Это - строка символов" +ss1 +'Это - строка символов' + +ss1a="Это - \" строка символов \", \n \t выводимая на двух строках" +print(ss1a) +Это - " строка символов ", + выводимая на двух строках +ss1b= 'Меня зовут: \n Хатюхин Е.С.' +ss1b +'Меня зовут: \n Хатюхин Е.С.' +ss1b='Меня зовут: \n Хатюхин Е.С.' +print(ss1b) +Меня зовут: + Хатюхин Е.С. +mnogo="""Нетрудно заметить , что в результате операции +над числами разных типов получается число, +имеющее более сложный тип из тех, которые участвуют в операции.""" + +print(mnogo) +Нетрудно заметить , что в результате операции +над числами разных типов получается число, +имеющее более сложный тип из тех, которые участвуют в операции. +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]='=' # Будет диагностика! +Traceback (most recent call last): + File "", line 1, in + ss1[4]='=' # Будет диагностика! +TypeError: 'str' object does not support item assignment +ss2 = ss1[:6] + ss1b[-12:] +ss2 +'Это - Хатюхин Е.С.' +spis1=[111,'Spisok',5-9j] +stup=[0,0,1,1,1,1,1,1,1] +spis=[1,2,3,4, +5,6,7, +8,9,10] +spis1[-1] +(5-9j) +stup[-8::2] # вошло 4 элемента, начиная со 2 через 1(если по индексам: 1,3,5,7) +[0, 1, 1, 1] +spis1[1]='Список' +spis1 +[111, 'Список', (5-9j)] +len(spis1) +3 +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') # В конец списка добавлен элемент «New item» +spis1+['New item'] +[111, 'Список', (5-9j), 'New item', 'New item'] +spis1.append('New item') # В конец списка добавлен элемент «New item» +spis1.append(ss1b) +spis1 +[111, 'Список', (5-9j), 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.'] +spis1.pop(1) #Из списка удален элемент с индексом 1 +'Список' +stup.insert(1,2) +stup +[0, 2, 0, 1, 1, 1, 1, 1, 1, 1] +stup.insert(2,123) +stup +[0, 2, 123, 0, 1, 1, 1, 1, 1, 1, 1] +stup.remove(123) +stup +[0, 2, 0, 1, 1, 1, 1, 1, 1, 1] +last = [4,6,8 + ] +stup.extend(last) +stup +[0, 2, 0, 1, 1, 1, 1, 1, 1, 1, 4, 6, 8] +stup.sort() +stup +[0, 0, 1, 1, 1, 1, 1, 1, 1, 2, 4, 6, 8] +stup.reverse() +stup +[8, 6, 4, 2, 1, 1, 1, 1, 1, 1, 1, 0, 0] +stup.copy() +[8, 6, 4, 2, 1, 1, 1, 1, 1, 1, 1, 0, 0] +stup.count(1) +7 +stup.index(2) +3 +stup.clear() +stup +[] +spis2=[spis1,[4,5,6,7]] #здесь элементами являются два списка +spis2[0][1] #обращение к элементу списка spis1 +(5-9j) +spis2[0][1]=78 #Убедитесь, что значение элемента заменено на 78 +spis2[0][1] +78 +spis1 +[111, 78, 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.'] +# список 1 изменился, потому что он входит в элементы списка 2 не как копия, а как ссылка, поэтому любое изменение элементов списка 1 через список 2 приведет к изменению списка 1 как отделной переменной +a = 5 +b = True +spisok = [a,ss2,b,spis1] +spisok +[5, 'Это - Хатюхин Е.С.', True, [111, 78, 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.']] +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) # Будет получено значение 4 +4 +kort1.count(222) #Будет получено значение 1 +1 +kort1[2]=90 #Будет получена диагностика о невозможности изменения кортежа +Traceback (most recent call last): + File "", line 1, in + kort1[2]=90 #Будет получена диагностика о невозможности изменения кортежа +TypeError: 'tuple' object does not support item assignment +korteg = (a,ss1,b,spisok,kort1) +korteg +(5, 'Это - строка символов', True, [5, 'Это - Хатюхин Е.С.', True, [111, 78, 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.']], (222, 'Kortezh', (77+8j), 1, 2, 'Меня зовут: \n Хатюхин Е.С.')) +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'} +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])) +kort7 = (1,2,3,4,5,6,7) +kort7 +(1, 2, 3, 4, 5, 6, 7) +lis5 = ['a','b','c','d','e'] +lis5 +['a', 'b', 'c', 'd', 'e'] +dic6 = dict(zip(kort7,lis5)) +dic6 +{1: 'a', 2: 'b', 3: 'c', 4: 'd', 5: 'e'} +#Длинна нашего словаря равна 5, поскольку zip объединяет элементы в словарь по минимальной длинне аргументов +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 +mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'} +mnoz1 +{'двигатель', 'датчик', 'микропроцессор', 'линия связи'} +len(mnoz1) +4 +'датчик' in mnoz1 +True +mnoz1.add('реле') +mnoz1.remove('линия связи') +mnoz2 = {1, True, long, int, 24, Евгений} +Traceback (most recent call last): + File "", line 1, in + mnoz2 = {1, True, long, int, 24, Евгений} +NameError: name 'long' is not defined +mnoz2 = {1, True, 'long', 'int', 24, 'Евгений'} +mnoz2 +{1, 24, 'int', 'Евгений', 'long'} +'True' in mnoz2 +False +mnoz2.add("True") +'True' in mnoz2 +True + diff --git a/TEMA2/protocol.py b/TEMA2/protocol.py new file mode 100644 index 0000000..e69de29 diff --git a/TEMA2/report.md b/TEMA2/report.md new file mode 100644 index 0000000..ee2c326 --- /dev/null +++ b/TEMA2/report.md @@ -0,0 +1,349 @@ +# Отчет по теме 2 +Хатюхин Евгений, А-02-23 + +## 1 Создание протокола и настройка рабочей среды +## 2 Простые объекты +Я создал 2 простых объекта, проверил их значения, убедился, что они присутствуют в памяти компьютера, узнал тип одного из объектов, удалил эти объекты и убедился, что они пропали из памяти компьютера. +```py +f1=16; f2=3 +f1,f2 +(16, 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'] +type(f2) + +del f1,f2 +dir() +['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__'] +``` +## 3 Изучил правила именования объектов в пайтон и проверил их на практике +```py +gg1=1.6 #значение в виде вещественного числа +hh1='Строка' #значение в виде символьной строки +73sr=3 #неправильное имя – начинается с цифры - будет диагностика! +SyntaxError: invalid decimal literal +and=7 #недопустимое имя – совпадает с ключевым словом - будет диагностика! +SyntaxError: invalid syntax +dir() +['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'gg1', 'hh1'] +``` +## 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'] +kl = keyword.kwlist +kl +['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 Просмотрел список встроенных идентификаторов и изучил некоторые из них с помощью функции help +- abs - выдает значение по модулю +- len - выдает длину объекта +- max - выдает максимальное число из списка введенных в аргумент +- min - выдает минимальное число из списка введенных в аргумент +- pow - при двух аргументах: возводит первый в степень второго. При наличие третьего аргумента делит получившийся результат на третий аргумент и показывает остаток +- round - округляет число до целого ,если 1 аргумент. При наличие второго аргумента округляет до стольких цифр после запятой, сколько указано во втором аргументе +- sorted - сортирует числа или буквы по возрастанию или убыванию +- sum - суммирует числа +- zip - создает итератор, который объединяет элементы из нескольких перебираемых объектов по соответствию. +```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'] +abs(-10) +10 +len("len") +3 +max(1,25) +25 +min(1,25) +1 +pow(2,3) +8 +pow(2,3,3) +2 +round(2.85) +3 +round(2.855,2) +2.85 +round(2.856,2) +2.86 +sorted("cba") +['a', 'b', 'c'] +sum([3,7]) +10 +list(zip([1,2,3],['a','b','c'])) +[(1, 'a'), (2, 'b'), (3, 'c')] +``` +## 6 Убедился, что переменные чувствительны к регистру +```py +Gg1 = 45 +gg1 +1.6 +Gg1 +45 + +``` +## 7 Изучил простые базовые объекты +### 7.1 Изучил логический тип данных(bool) +```py +bb1=True; bb2=False +bb1;bb2 +True +False +type(bb1) + +``` +### 7.2 Изучил другие простые типы данных(int,float,complex) +```py +ii1=-1234567890 +ff1=-8.9876e-12 #экспоненциальная форма записи вещественного числа +dv1=0b1101010 #Это – двоичное число. В объекте какого класса оно сохранено? +type(dv1) + +vsm1=0o52765 #Это – восьмеричное число +type(vsm1) + +shest1=0x7109af6 #Это – шестнадцатеричное число +type(shest1) + +cc1=2-3j +type(cc1) + +a=3.67; b=-0.45 +cc2=complex(a,b) #Создается комплексное число +``` +### 7.3 Изучил тип объекта - строка-символ +```py +ss1='Это - строка символов' +ss1 +'Это - строка символов' +ss1="Это - строка символов" +ss1 +'Это - строка символов' + +ss1a="Это - \" строка символов \", \n \t выводимая на двух строках" +print(ss1a) +Это - " строка символов ", + выводимая на двух строках +ss1b= 'Меня зовут: \n Хатюхин Е.С.' +ss1b +'Меня зовут: \n Хатюхин Е.С.' +ss1b='Меня зовут: \n Хатюхин Е.С.' +print(ss1b) +Меня зовут: + Хатюхин Е.С. +mnogo="""Нетрудно заметить , что в результате операции +над числами разных типов получается число, +имеющее более сложный тип из тех, которые участвуют в операции.""" + +print(mnogo) +Нетрудно заметить , что в результате операции +над числами разных типов получается число, +имеющее более сложный тип из тех, которые участвуют в операции. +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]='=' # Будет диагностика! +Traceback (most recent call last): + File "", line 1, in + ss1[4]='=' # Будет диагностика! +TypeError: 'str' object does not support item assignment +ss2 = ss1[:6] + ss1b[-12:] +ss2 +'Это - Хатюхин Е.С.' +``` +## 8 Изучил более сложные типы данных +### 8.1 Изучил список и проверил на практике некоторые его методы +```py +spis1=[111,'Spisok',5-9j] +stup=[0,0,1,1,1,1,1,1,1] +spis=[1,2,3,4, +5,6,7, +8,9,10] +spis1[-1] +(5-9j) +stup[-8::2] # вошло 4 элемента, начиная со 2 через 1(если по индексам: 1,3,5,7) +[0, 1, 1, 1] +spis1[1]='Список' +spis1 +[111, 'Список', (5-9j)] +len(spis1) +3 +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') # В конец списка добавлен элемент «New item» +spis1+['New item'] +[111, 'Список', (5-9j), 'New item', 'New item'] +spis1.append('New item') # В конец списка добавлен элемент «New item» +spis1.append(ss1b) +spis1 +[111, 'Список', (5-9j), 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.'] +spis1.pop(1) #Из списка удален элемент с индексом 1 +'Список' +``` +Методы: +- insert - вставляет элемент соответствующий второму аргументу на индекс равный первому аргументу +- remove - удаляет первый элемент из списка, который соответствует значению аргумента +- extend - добaвляет в конец списка все элемента из объекта в аргументе +- sort - сортирует элементы по порядку +- reverse - переворачивает порядок элементов списка +- copy - создает копию списка +- count - возвращает число, сколько раз элемент из аргумента встречается в списке +- index - возвращает индекс первого вхождения элемента соответствующему аргументу. +- clear - очищает список +```py +stup.insert(1,2) +stup +[0, 2, 0, 1, 1, 1, 1, 1, 1, 1] +stup.insert(2,123) +stup +[0, 2, 123, 0, 1, 1, 1, 1, 1, 1, 1] +stup.remove(123) +stup +[0, 2, 0, 1, 1, 1, 1, 1, 1, 1] +last = [4,6,8 + ] +stup.extend(last) +stup +[0, 2, 0, 1, 1, 1, 1, 1, 1, 1, 4, 6, 8] +stup.sort() +stup +[0, 0, 1, 1, 1, 1, 1, 1, 1, 2, 4, 6, 8] +stup.reverse() +stup +[8, 6, 4, 2, 1, 1, 1, 1, 1, 1, 1, 0, 0] +stup.copy() +[8, 6, 4, 2, 1, 1, 1, 1, 1, 1, 1, 0, 0] +stup.count(1) +7 +stup.index(2) +3 +stup.clear() +stup +[] +``` +```py +spis2=[spis1,[4,5,6,7]] #здесь элементами являются два списка +spis2[0][1] #обращение к элементу списка spis1 +(5-9j) +spis2[0][1]=78 #Убедитесь, что значение элемента заменено на 78 +spis2[0][1] +78 +spis1 +[111, 78, 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.'] +# список 1 изменился, потому что он входит в элементы списка 2 не как копия, а как ссылка, поэтому любое изменение элементов списка 1 через список 2 приведет к изменению списка 1 как отделной переменной +a = 5 +b = True +spisok = [a,ss2,b,spis1] +spisok +[5, 'Это - Хатюхин Е.С.', True, [111, 78, 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.']] +``` +### 8.2 Изучил объект-кортеж +```py +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) # Будет получено значение 4 +4 +kort1.count(222) #Будет получено значение 1 +1 +kort1[2]=90 #Будет получена диагностика о невозможности изменения кортежа +Traceback (most recent call last): + File "", line 1, in + kort1[2]=90 #Будет получена диагностика о невозможности изменения кортежа +TypeError: 'tuple' object does not support item assignment +korteg = (a,ss1,b,spisok,kort1) +korteg +(5, 'Это - строка символов', True, [5, 'Это - Хатюхин Е.С.', True, [111, 78, 'New item', 'New item', 'Меня зовут: \n Хатюхин Е.С.']], (222, 'Kortezh', (77+8j), 1, 2, 'Меня зовут: \n Хатюхин Е.С.')) +``` +### 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'} +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])) +kort7 = (1,2,3,4,5,6,7) +kort7 +(1, 2, 3, 4, 5, 6, 7) +lis5 = ['a','b','c','d','e'] +lis5 +['a', 'b', 'c', 'd', 'e'] +dic6 = dict(zip(kort7,lis5)) +dic6 +{1: 'a', 2: 'b', 3: 'c', 4: 'd', 5: 'e'} +#Длинна нашего словаря равна 5, поскольку zip объединяет элементы в словарь по минимальной длинне аргументов +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.remove('линия связи') +mnoz2 = {1, True, long, int, 24, Евгений} +Traceback (most recent call last): + File "", line 1, in + mnoz2 = {1, True, long, int, 24, Евгений} +NameError: name 'long' is not defined +mnoz2 = {1, True, 'long', 'int', 24, 'Евгений'} +mnoz2 +{1, 24, 'int', 'Евгений', 'long'} +'True' in mnoz2 +False +mnoz2.add("True") +'True' in mnoz2 +True +``` +## 9 Завершил сеанс работы в IDLE \ No newline at end of file diff --git a/TEMA2/task.md b/TEMA2/task.md new file mode 100644 index 0000000..9de8aee --- /dev/null +++ b/TEMA2/task.md @@ -0,0 +1,48 @@ +# Общее контрольное задание по теме 2 + +Хатюхин Евгений А-02-23 + +## Задание + +•Создать переменную с именем familia и со значением - символьной строкой – своей фамилией в латинской транскрипции. + +•Создать переменную со значением, совпадающим с первой буквой из familia. + +•Создать переменную с именем sp_kw со значением – списком всей ключевых слов языка Python. + +•Удалите из списка sp_kw значение 'nonlocal'. Выводом списка в командном окне IDLE убедитесь, что это значение удалено из списка. + +•Создайте кортеж kort_nam с именами: вашим и еще 3-х студентов из вашей группы. Напишите инструкцию, позволяющую убедиться, что тип переменной – это tuple. + +•Напишите инструкцию, добавляющую в kort_nam имена еще двух студентов. + +•Напишите инструкцию, позволяющую определить, сколько раз в кортеже присутствуют студенты с именем «Дима». + +•Создайте словарь dict_bas, в котором ключами являются русские названия типов переменных, использованных в предыдущих операторах, а значениями – ранее созданные переменные, соответствующие этим типам. + +## Решение + +```py +familia = 'KhatiukhinYS' +f = familia[0] +f +'K' +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'] +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_name = ('Jenya','Stas','Lena','Andrew') +type(kort_nam) + +kort_nam = kort_nam + ('Dima','Denis') +kort_nam +('Jenya', 'Stas', 'Lena', 'Andrew', 'Dima', 'Denis') +kort_nam.count('Dima') +1 +dict_bas = dict(zip(('str','list','tuple'),(familia,sp_kw,kort_nam))) +dict_bas +{'str': 'KhatiukhinYS', 'list': ['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'], 'tuple': ('Jenya', 'Stas', 'Lena', 'Andrew', 'Dima', 'Denis')} +``` \ No newline at end of file