# Отчет по теме 3 Ефимова Людмила, А-03-23 ## 1. Запустила оболочку IDLE, создала рабочий протокол ## 2. Преобразование простых базовых типов объектов ### 2.1. Преобразовали объекты в логческий тип ```py logiz1=bool(56) # целые числа, кроме 0, преобразуются в True print(logiz1, ' ', type(logiz1)) True logiz2=bool(0) # 0 преобразуется в False print(logiz2, ' ', type(logiz2)) False logiz3=bool("Beta") # не пустая строка преобразуется в True print(logiz3, ' ', type(logiz3)) True logiz4=bool("") # пустая строка преобразуется в False print(logiz4, ' ', type(logiz4)) False ``` ### 2.2. Преобразование в целое десятичное число Функция int(<Объект>[,<Система счисления, в которой определен объект>]) позволяет преобразовать объект в целое десятичное число ```py tt1=int(198.6) #Отбрасывается дробная частьtt1 198 tt2=int("-76") #Число – в строке символов, система по умолчанию - десятичная tt2 -76 tt3=int("B",16) tt3 11 tt4=int("71",8) tt4 57 tt5=int("98.76") # Число передающееся в виде строки должно быть целым Traceback (most recent call last): File "", line 1, in tt5=int("98.76") ValueError: invalid literal for int() with base 10: '98.76' ``` С помощью функции float(<Объект>) преобразуем объекты в вещественное число ```py flt1=float(789) flt1 789.0 flt2=float(-6.78e2) flt2 -678.0 flt3=float("Infinity") flt3 inf flt4=float("-inf") flt4 -inf ``` ### 2.3. Преобразование десятичных чисел в другие системы счисления С помощью команд bin oct hex преобразовали объекты в строку с двоичным, вомьмеричным, шестнадцатиричным представлениями. С помощью команды int() сделали обратные преобразования. ```py hh=123 dv1=bin(hh) #Преобразование в строку с двоичным представлением dv1 '0b1111011' vos1=oct(hh) # Преобразование в строку с восьмеричным представлением vos1 '0o173' shs1=hex(hh) # Преобразование в строку с шестнадцатеричным представлением shs1 '0x7b' int(dv1, 2) 123 int(vos1, 8) 123 int(shs1, 16) 123 ``` ## 3. Преобразование более сложных элементов ### 3.1. Преобразование в строку символов Преобразовали объект в строку функцией str(<Объект>) ```py strk1=str(23.6) strk1 '23.6' strk2=str(logiz3) strk2 'True' strk3=str(["A","B","C"]) #Преобразуем список strk3 "['A', 'B', 'C']" strk4=str(("A","B","C")) #Преобразуем кортеж strk4 "('A', 'B', 'C')" strk5=str({"A":1,"B":2,"C":9}) #Преобразуем словарь strk5 "{'A': 1, 'B': 2, 'C': 9}" ``` ### 3.2. Преобразование объектов в список Преобразовали объекты в список функцией list(<Объект>). ```py spis1=list("Строка символов") #Заданная строка разделяется на символы spis1 ['С', 'т', 'р', 'о', 'к', 'а', ' ', 'с', 'и', 'м', 'в', 'о', 'л', 'о', 'в'] spis2=list((124,236,-15,908)) #Кортеж превращается в список spis2 [124, 236, -15, 908] spis3=list({"A":1,"B":2,"C":9}) #Преобразование словаря в список spis3 ['A', 'B', 'C'] spis4=list({"A":1, "B":2, "C":9}.values()) #Преобразование значений в список spis4 [1, 2, 9] spis5=list({"A":1,"B":2,"C":9}.items()) #Преобразование и ключей и значений в список spis5 [('A', 1), ('B', 2), ('C', 9)] ``` ### 3.3. Преобразование элементов объектов в кортеж Преобразуем объекты в кортеж функцией tuple(<Объект>). ```py kort7=tuple('Строка символов') #Преобразование строки символов в кортеж kort7 ('С', 'т', 'р', 'о', 'к', 'а', ' ', 'с', 'и', 'м', 'в', 'о', 'л', 'о', 'в') kort8=tuple(spis2) #Преобразование списка в кортеж kort8 (124, 236, -15, 908) kort9=tuple({"A":1,"B":2,"C":9}) #Преобразование словаря в кортеж kort9 ('A', 'B', 'C') ``` ### 3.4. Удаление объектов С помощью функции del можно удалить объекты из оперативной памяти ```py del strk5, kort8 dir() ['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'dv1', 'flt1', 'flt2', 'flt3', 'flt4', 'hh', 'kort7', 'kort9', 'logiz1', 'logiz2', 'logiz3', 'logiz4', 'shs1', 'spis1', 'spis2', 'spis3', 'spis4', 'spis5', 'spis6', 'strk1', 'strk2', 'strk3', 'strk4', 'tt1', 'tt2', 'tt3', 'tt4', 'vos1'] ``` Создадим строку со своей фамилией и инициалами преобразуем ее в список, затем список в кортеж, затем в строку ```py strk1 = "ЕфимоваЛА" spis = list(strk1) spis ['Е', 'ф', 'и', 'м', 'о', 'в', 'а', 'Л', 'А'] kort = tuple(spis) kort ('Е', 'ф', 'и', 'м', 'о', 'в', 'а', 'Л', 'А') strk2 = str(kort) "('Е', 'ф', 'и', 'м', 'о', 'в', 'а', 'Л', 'А')" ``` ## 4. Арифметические операции ### 4.1. Сложение и вычитание ```py 12+7+90 # Сложение целых чисел 109 5.689e-1 - 0.456 #Вычитание вещественных чисел 0.11289999999999994 23.6+54 #Сложение вещественного и целого чисел 77.6 14-56.7+89 # Сложение и вычитание целых и вещественных чисел 46.3 ``` ### 4.2. Умножение ```py -6.7*12 #Умножение вещественного числа на целое число -80.4 ``` ### 4.3. Деление Результатом деления всегда будет вещественное число ```py -234.5/6 #Деление вещественного числа на целое -39.083333333333336 a=178/45 #Деление двух целых чисел – проверьте тип объекта a! print(a, ' ', type(a)) 3.9555555555555557 ``` ### 4.4. Деление c округлением вниз ```py b = 178 // 45 # 3.956 округляется вниз, т.е. до 3 b 3 type(b) c = -24.6 // 12.1 # -2.033 округляется вниз, т.е. до -3 c -3.0 type(c) 12 // 6.5 1.0 12.0 // 5 2.0 ``` ### 4.5. Получение остатка от деления ```py 148%33 #Остаток от деления двух целых чисел 16 12.6%3.8 #Остаток от деления двух вещественных чисел 1.2000000000000002 ``` ### 4.6. Возведение в степень ```py 14**3 #Целое число возводится в целую степень 2744 e=2.7**3.6 #Вещественное число возводится в вещественную степень e 35.719843790663525 ``` С комплексными числами ```py z1 = 1 + 1j z2 = 2 + 2j z1+z2 (3+3j) z1 - z2 (-1-1j) z1 * z2 4j z1 / z2 (0.5+0j) z1 ** 2 2j z1 // 2 # Операция целочисленного деления неприменима к комплексным числам Traceback (most recent call last): File "", line 1, in z1 // 2 # Операция целочисленного деления неприменима к комплексным числам TypeError: unsupported operand type(s) for //: 'complex' and 'int' z1 % z2 # Операция получения остатка от деления также неприменима к комплексным числам Traceback (most recent call last): File "", line 1, in z1 % z2 # Операция получения остатка от деления также неприменима к комплексным числам TypeError: unsupported operand type(s) for %: 'complex' and 'complex' ``` При проведении арифметических операций над числами разных типов, получается число, имеющее более сложный тип из использованных при его получении. ## 5. Операции с двоичными представлениями целых чисел ### 5.1. Двоичная инверсия Двоичная инверсия (~). Значение каждого бита в представлении числа заменяется на противоположное значение (0 на 1, 1 на 0) ```py dv1=9 bin(dv1) '0b1001' dv2=~dv1 bin(dv2) '-0b1010' ``` ### 5.2. Двоичное «И» Двоичное «И» - логическое умножение, побитовое совпадение двоичных представлений чисел. ```py 7&9 # 0111 и 1001 = 0001 1 bin(7) '0b111' bin(9) '0b1001' 7&8 # 0111 и 1000 = 0000 0 bin(8) '0b1000' ``` ### 5.3. Двоичное «ИЛИ» Двоичное «ИЛИ» - логическое сложение, побитовое совпадение двоичных представлений чисел, в котором 0 получается, только если оба сравниваемых разряда равны 0. ```py 7|9 # 0111 или 1001 = 1111 15 7|8 # 0111 или 1000 = 1111 15 14|5 # 1110 или 0101 = 1111 15 bin(15) '0b1111' ``` ### 5.4. Двоичное «исключаещее ИЛИ» Двоичное «исключающее ИЛИ» - побитовое совпадение двоичных представлений чисел, в котором 0 получается, только если оба сравниваемых разряда имеют одинаковые значения. ```py 14^5 # 1110 исключающее или 0101 = 1011 11 bin(11) '0b1011' ``` ### 5.5. Поразрядный сдвиг Сдвиг двоичного представления на заданное число разрядов влево (<<) или вправо (>>) с дополнением нулями, соответственно справа или слева ```py h=14 #Двоичное представление = 1110 bin(h) '0b1110' g=h<<2 # Новое двоичное представление = 111000 bin(g) '0b111000' g1=h>>1 # Новое двоичное представление = 0111bin(g1) '0b111' g2=h>>2 # Новое двоичное представление = 0011 bin(g2) '0b11' ``` Операции с двоичными числами на практике ```py a = 251 bin(a) '0b11111011' b = 293 bin(b) '0b100100101' ~a -252 bin(~a) '-0b11111100' a&b # 011111011 и 100100101 = 000100001 33 bin(a&b) '0b100001' a|b # двоичное или - 011111011 и 100100101 = 111111111 511 bin(a|b) '0b111111111' a ^ b # Двоичное «исключающее ИЛИ» 0 если совпадают 478 bin(a^b) '0b111011110' bin(a>>3) # поразрядовый сдвиг вправо на 3 '0b11111' ``` ## 6. Операции при работе с последовательностями ### 6.1. Объединение последовательностей ```py 'Система '+'регулирования' #Соединение двух строк символов 'Система регулирования' ['abc','de','fg']+['hi','jkl'] # Объединение двух списков ['abc', 'de', 'fg', 'hi', 'jkl'] ('abc','de','fg')+('hi','jkl') # Объединение двух кортежей ('abc', 'de', 'fg', 'hi', 'jkl') ``` ### 6.2. Повторение (*) ```py 'ля-ля-ля-ля-ля-' ['ку','-']*3 #Повторение списка 3 раза ['ку', '-', 'ку', '-', 'ку', '-'] ('кис','-')*4 #Повторение кортежа 4 раза ('кис', '-', 'кис', '-', 'кис', '-', 'кис', '-') signal1=[0]*3+[1]*99 signal1 [0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] signal2=(0,)*3+(1,)*5+(0,)*7signal2 (0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0) ``` ### 6.3. Проверка наличия заданного элемента в последовательности Наличие элемента в последовательность можно проверить с помощью оператора in. ```py stroka='Система автоматического управления' 'автомат' in stroka #Наличие подстроки в строке True 'ку' in ['ку','-']*3 #Наличие контекста в списке True 'ля-' in ('abc', 'de', 'fg', 'hi', 'jkl') #Наличие контекста в кортеже False ``` ### 6.4. Подстановка значений в строку В строку символов можно подставлять заданные значения с помощью оператора %. ```py stroka='Температура = %g %s %g' stroka 'Температура = %g %s %g' stroka % (16,' меньше ',25) 'Температура = 16 меньше 25' stroka='Температура = %(zn1)g %(sravn)s %(zn2)g' # вставка и сспользованием данных из словаря stroka % {'zn1':16,'sravn':' меньше ','zn2':25} 'Температура = 16 меньше 25' ``` ## 7. Оператор присваивания ### 7.1. Обычное присваивание значения переменной ```py zz=-12 zz -12 ``` ### 7.2. Увеличение значения переменной на заданную величину или уменьшение Операторы += и -= позволяют увеличить или уменьшить значение переменной на заданную величину соответственно. ```py zz+=5 # Значение zz увеличивается на 5 zz -7 zz-=3 # Значение уменьшается на 3 zz -10 stroka='Система' stroka+=' регулирования' stroka+=' регулирования' stroka 'Система регулирования' ``` ### 7.3. Умножение текущего значения переменной на заданную величину или деление Операторы /= и *= позволяют разделить или умножить значение переменной на заданную величину соответственно. ```py zz/=2 zz -5.0 zz*=5 zz -12.5 str = 'ля' str*=3 # повторение заданной строки 3 раза str 'ляляля' ``` ### 7.4. Операции деления с округлением вниз получения остатка от деления и возведения в степень ```py a = 6 a//=5 # целочисленное деление a 1 b = 13 b%=6 # получение остатка от деления b 1 c = 2 c **= 3 # возведение в степень c 8 ``` ### 7.5. Множественное присваивание Присваивать определенные значения можно сразу нескольким переменным за раз. ```py w=v=10 # Переменным присваивается одно и то же значение w,v (10, 10) n1,n2,n3=(11,-3,'all') #Значения переменных берутся из кортежа n1,n2,n3 (11, -3, 'all') n1,n2,n3= [11, 12, 13] # можно из списка n1, n2, n3 (11, 12, 13) n1,n2,n3= '12','rrr', 'iuuiui' # можно строки n1, n2, n3 ('12', 'rrr', 'iuuiui') n1,n2,n3= {1: 11, 2: 12, 3: 'eeee'} # можно словарь n1, n2, n3 (1, 2, 3) n1,n2,n3= {11, 12, 'eeee'} # множество n1, n2, n3 (11, 12, 'eeee') ``` ## 8. Логические операции ### 8.1. Операции сравнения ```py w == v True w != v False w +=1 w < v False w > v True w <= v False w>=v True ``` ### 8.2. Проверка наличия заданного элемента в последовательности или во множестве, а также проверка наличия ключа в словаре Наличие элемента в сложном объекте также можно проверить с помощью оператора in ```py mnoz1={'pen','book','pen','iPhone','table','book'} # с множеством 'book' in mnoz1True 'cap' in mnoz1 False dic1={'Saratov':145, 'Orel':56, 'Vologda':45} # со словарем 'Vologda' in dic1 True 'Pskov' in dic1 False 56 in dic1.values() # проверка наличия значения в словаре True dct1={'Institut':['AVTI','IEE','IBB'],'Depart':['UII','PM','VMSS','MM'],'gruppa': ['A01-15','A-02-15']} 'UII' in dct1['Depart'] True dct1['Depart'][1] == 'MM' # сравнение значения словаря по ключу False ``` ### 8.3. Создание больших логических выражений С помощью соединительных слов and, or и not можно создавать большие логические выражения. ```py a=17 b=-6 (a>=b) and ('book' in mnoz1) and not ('Pskov' in dic1) True (a%2==1) and ("pen" in mnoz1) or (120 in dic1.values()) True not (b < 0) or (len(mnoz1)== 4) True ``` ### 8.4. Проверка ссылок переменных на один и тот же объект Сравнивать ссылки на объект можно с помощью оператора is. ```py w=v=10 #При таком присваивании переменные ссылаются на один и тот же объект в оперативной памяти w is v True w1=['A','B'] v1=['A','B'] w1 is v1 False ``` В последнем случае значение False так как переменные создавались отдельно, хоть их значения и совпадают. Они хранятся в разных ячейках памяти и их ссылки разные. ## 9. Операции с объектами, выполняемые с помощью методов ### 9.1 Методы для работы со строками ```py stroka='Микропроцессорная система управления' dir(stroka)['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'removeprefix', 'removesuffix', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill'] stroka.find('пр') #Возвращает номер позиции первого вхождения указанного контекста или значение -1 5 stroka='Микропроцессорная система управления' stroka.find('пр') #Возвращает номер позиции первого вхождения указанного контекста или значение -1 5 stroka.count("с") #Подсчет числа вхождений строки “с” в stroka 4 stroka.replace(' у',' автоматического у') 'Микропроцессорная система автоматического управления' spis22=stroka.split(' ') #Возвращает список подстрок, между которыми в строке стоит заданный разделитель spis22 ['Микропроцессорная', 'система', 'управления'] stroka.upper() #Возвращает строку со всеми заглавными буквами 'МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ' stroka3=" ".join(spis22) #Возвращает строку, собранную из элементов списка stroka3 'Микропроцессорная система управления' stroka3.partition("с") #Возвращает кортеж с результатами поиска «с» слева('Микропроце', 'с', 'сорная система управления') stroka3.rpartition("с") #Возвращает кортеж с результатами поиска «с» справа ('Микропроцессорная си', 'с', 'тема управления') ``` Метод format() используется для форматирования строк по следующему принципу: 1. Если в форматированной строке не указан порядок вставки элементов, то они войдут в неё в порядке их передачи в метод, 2. Если в форматированной строке указан порядок вставки элементов, то они войдут в неё в с таким же порядком, 3. Если в форматированной строке поименно указаны позиции вставки элементов, то они войдут в неё в соответствии с ними. ```py strk1='Момент времени {}, значение = {}' strk1.format(1,89.7) 'Момент времени 1, значение = 89.7' strk2='Момент времени {1}, значение = {0}:{2}' # в фигурных скобках индексы, определяеют порядок аргументов формата strk2.format(36.7,2,'норма!') 'Момент времени 2, значение = 36.7:норма!' strk3='Момент времени {num}, значение = {znch}' # в фигурных скобках имена аргументов strk3.format(znch=89.7,num=2) 'Момент времени 2, значение = 89.7' ``` ### 9.2. Методы для работы со списками ```py spsk = [1, 2, 3, 4, 5, 6] spsk.pop(2) # удаление элемента по индексу, с возвращением его значения 3 spsk [1, 2, 4, 5, 6] spsk.append('c') # добавление элемента в конец списка spsk [1, 2, 4, 5, 6, 'c'] spsk.insert(2,'a') # добавление элемента на указанную позицию spsk [1, 2, 'a', 4, 5, 6, 'c'] spsk.count('a') # подсчет количества соответсвующих элементо 1 ``` ### 9.3. Методы для работы с кортежами ```py kortezh = (1, 2, 3, 4, 5, 6, 7) kortezh.count(3) # количество соответсвующих элементов в кортеже 1 kortezh.index(2) # вычисление индекса переданного элемента если он есть в кортеже 1 ``` ### 9.4. Методы для словарей и множеств ```py dictionary = {"A" : 1, "B" : 2, "C" : 3, "D" : 4, "E" : 5} dictionary.get("D") # Получение значения из словаря по соответствующему ему ключу dictionary.items() # Получение списка кортежей всех пар ключ-значений в словаре dict_items([('A', 1), ('B', 2), ('C', 3), ('D', 4), ('E', 5)]) dictionary.keys() # Получение списка всех ключей в словаре dict_keys(['A', 'B', 'C', 'D', 'E']) dictionary.values() # Получение списка всех значений в словаре dict_values([1, 2, 3, 4, 5]) dictionary.pop("C") # Удаление определенной пары ключ-значение из словаря по переданному ключу 3 dictionary {'A': 1, 'B': 2, 'D': 4, 'E': 5} dictionary.popitem() # Удаление последней пары ключ-значение из словаря ('E', 5) dictionary {'A': 1, 'B': 2, 'D': 4} dictionary.update({"A" : 5}) # Обновление словаря новыми значениями dictionary {'A': 5, 'B': 2, 'D': 4} dictionary.clear() # Очистка словаря dictionary {} ``` Методы для работы с множествами отчасти схожи с методами словарей, однако среди них также есть и уникальные методы. ```py mnozhestvo = {"Apple", "Orange", "Peach", "Pear"} mnozhestvo.add("Banana") # Добавление элемента в множество mnozhestvo {'Banana', 'Pear', 'Peach', 'Apple', 'Orange'} mnozhestvo2 = mnozhestvo.copy() # Копирование множества mnozhestvo2 {'Peach', 'Banana', 'Apple', 'Orange', 'Pear'} mnozhestvo2.remove("Apple") # Удаление элемента из множества mnozhestvo2 {'Peach', 'Banana', 'Orange', 'Pear'} mnozhestvo.difference(mnozhestvo2) # Сравнение двух множеств по содержимому, возвращает разницу {'Apple'} mnozhestvo2.clear() # Очистка множества mnozhestvo2 set() ``` ## 10. Завершение работы со средой.