форкнуто от main/python-labs
Вы не можете выбрать более 25 тем
Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
532 строки
22 KiB
Markdown
532 строки
22 KiB
Markdown
# Отчет по Теме 2
|
|
|
|
Савин Семён, А-02-23
|
|
|
|
## Пункт 2. Изучение простых объектов
|
|
|
|
Переменным f1 и f2 были присвоены значения (целые числа).
|
|
```py
|
|
>>> import os
|
|
>>> os.chdir ('C:\\Users\\somas\\python-labs\\TEMA2')
|
|
>>> f1 = 16; f2 = 3
|
|
>>> f1, f2
|
|
(16, 3)
|
|
>>> f1;f2
|
|
16
|
|
3
|
|
```
|
|
|
|
Проверяем, какие объекты есть в среде python, а также выводим атрибуты для переменной f1.
|
|
```py
|
|
>>> 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__', '__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_length', 'conjugate', 'denominator', 'from_bytes', 'imag', 'numerator', 'real', 'to_bytes']
|
|
```
|
|
Выводим класс переменной f2 и удаляем обе переменные с проверкой удаления.
|
|
|
|
```py
|
|
>>> type (f2)
|
|
<class 'int'>
|
|
>>> del f1,f2
|
|
>>> f1,f2
|
|
Traceback (most recent call last):
|
|
File "<pyshell#10>", line 1, in <module>
|
|
f1,f2
|
|
NameError: name 'f1' is not defined
|
|
>>> f2
|
|
Traceback (most recent call last):
|
|
File "<pyshell#11>", line 1, in <module>
|
|
f2
|
|
NameError: name 'f2' is not defined
|
|
```
|
|
|
|
## Пункт 3. Правила именования объектов
|
|
Создал несколько переменных разных типов, а также с неверным названием.
|
|
```py
|
|
>>> ggl = 1.6
|
|
>>> hhl = 'Строка'
|
|
>>> 73sr = 3
|
|
SyntaxError: invalid syntax
|
|
>>> and = 7
|
|
SyntaxError: invalid syntax
|
|
```
|
|
## Пункт 4. Просмотр ключевых слов
|
|
|
|
Был выведен и сохранен в переменной keylist список ключевых слов.
|
|
```py
|
|
>>> keyword.kwlist
|
|
['False', 'None', 'True', '__peg_parser__', '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']
|
|
>>> keylist = keyword.kwlist
|
|
>>> keylist
|
|
['False', 'None', 'True', '__peg_parser__', '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', 'BlockingIOError', 'BrokenPipeError', 'BufferError', 'BytesWarning', 'ChildProcessError', 'ConnectionAbortedError', 'ConnectionError', 'ConnectionRefusedError', 'ConnectionResetError', 'DeprecationWarning', 'EOFError', 'Ellipsis', 'EnvironmentError', 'Exception', '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', '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', '_', '__build_class__', '__debug__', '__doc__', '__import__', '__loader__', '__name__', '__package__', '__spec__', 'abs', 'all', '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 - модуль от числа
|
|
max/min - вывод максимального/минимального числа для либо списка либо для нескольких перечисленных переменных
|
|
len - выводит кол-во объектов в контейнере
|
|
pow - возводит число в степень
|
|
round - округляет число
|
|
sum - дает сумму всех элементов в контейнере
|
|
sorted - сортирует по возрастанию элементы в контейнере
|
|
zip - "сшивает" значения из одной последовательности значений с соответвтвующими значениями из другой
|
|
|
|
```py
|
|
>>> x = -3
|
|
>>> abs(x)
|
|
3
|
|
>>> pow(x,2)
|
|
9
|
|
>>> x = 1.576
|
|
>>> round(x)
|
|
2
|
|
>>> x = 1.50
|
|
>>> round(x)
|
|
2
|
|
```
|
|
|
|
## Пункт 6. Значимость регистра
|
|
|
|
При присваивании имен переменным важен также регистр букв.
|
|
|
|
```py
|
|
>>> x = 1.576
|
|
>>> round(x)
|
|
2
|
|
>>> x = 1.50
|
|
>>> round(x)
|
|
2
|
|
```
|
|
|
|
## Пункт 7. Изучение простых базовых типов.
|
|
|
|
## 7.1. Логический тип
|
|
|
|
```py
|
|
>>> bb1 = True; bb2 = False
|
|
>>> bb1,bb2
|
|
(True, False)
|
|
>>> type(bb1)
|
|
<class 'bool'>
|
|
```
|
|
|
|
## 7.2. Другие простые типы
|
|
|
|
Изучены некоторые другие типы числовых переменных
|
|
|
|
```py
|
|
>>> ii1 = -1234567890
|
|
>>> type(ii1)
|
|
<class 'int'>
|
|
>>> ff1 = -8.9876e-12
|
|
>>> type(ff1)
|
|
<class 'float'>
|
|
>>> dv1 = 0b1101010
|
|
>>> type(dv1)
|
|
<class 'int'>
|
|
>>> vsm1 = 0o52765
|
|
>>> shest1 = 0x7109af6
|
|
>>> ccl = 2-3j
|
|
>>> a = 3.67; b = -0.45
|
|
>>> cc2 = complex(a,b)
|
|
>>> cc2
|
|
(3.67-0.45j)
|
|
>>> type(cc2)
|
|
<class 'complex'>
|
|
```
|
|
|
|
## 7.3. Строка
|
|
|
|
Также изучили разные способы вывода простой строки с помощью "экранированных последовательностей"
|
|
|
|
```py
|
|
>>> ss1 = 'this is a string'
|
|
>>> print(ss1)
|
|
this is a string
|
|
>>> ss1a = "this is a \" string \", \n \t printed on two lines"
|
|
>>> print(ss1a)
|
|
this is a " string ",
|
|
printed on two lines
|
|
>>> ss1b = "my name is: \n Savin S.A."
|
|
>>> print(ss1b)
|
|
my name is:
|
|
Savin S.A.
|
|
```
|
|
|
|
Также вывели многострочное предложение с помощью тройных кавычек
|
|
|
|
```py
|
|
>>> mnogo="""Нетрудно заметить , что в результате операции
|
|
над числами разных типов получается число,
|
|
имеющее более сложный тип из тех, которые участвуют в операции."""
|
|
>>> print(mnogo)
|
|
Нетрудно заметить , что в результате операции
|
|
над числами разных типов получается число,
|
|
имеющее более сложный тип из тех, которые участвуют в операции.
|
|
```
|
|
|
|
Изучил действия со сторокой - вывд определенных букв по индексу в строке, а так же разрезание строки(с шагами 1 и 2)
|
|
|
|
```py
|
|
>>> ss1[0]
|
|
't'
|
|
>>> ss1[8]
|
|
'a'
|
|
>>> ss1[-2]
|
|
'n'
|
|
>>> ss1[6:9]
|
|
's a'
|
|
>>> ss1[13:]
|
|
'ing'
|
|
>>> ss1[5:-8]
|
|
'is '
|
|
>>> ss1[3:17:2]
|
|
'si tig'
|
|
>>> ss1[17:3:-2]
|
|
'git i'
|
|
>>> ss1[-4:3:-2]
|
|
'rsas '
|
|
```
|
|
(Изначальная строка - this is a string)
|
|
|
|
При изменении строки случается ошибка - так как строка неизменяема. Однако при переопределении можно внести изменения.
|
|
|
|
```py
|
|
>>> ss1[4] = '='
|
|
Traceback (most recent call last):
|
|
File "<pyshell#88>", line 1, in <module>
|
|
ss1[4] = '='
|
|
TypeError: 'str' object does not support item assignment
|
|
>>> ss1 = ss1[:4] + '+' + ss1[5:]
|
|
>>> ss1
|
|
'this+is a string'
|
|
```
|
|
|
|
Самостоятельно поработал со строкой ss1b - двухстрочное предложение. А также удалил старые значения x,y, заменив на другие.
|
|
Проверил их тип.
|
|
|
|
```py
|
|
>>> ss1b[4:17:2]
|
|
'aei:\nSv'
|
|
>>> ss1b[16:]
|
|
'vin S.A.'
|
|
>>> ss1b[14:]
|
|
'Savin S.A.'
|
|
>>> del x
|
|
>>> del y
|
|
>>> x = True
|
|
>>> y = 14-5j
|
|
>>> type(x);type(y)
|
|
<class 'bool'>
|
|
<class 'complex'>
|
|
```
|
|
|
|
## Пункт 8. Изучение более сложных типов.
|
|
|
|
## 8.1. Список
|
|
|
|
Работа со списками - можно задать любые значение и типы. Список - упорядоченная коллекция объектов.
|
|
```py
|
|
>>> spis1 = [111,'spisok', 5-9j]
|
|
>>> spis1
|
|
[111, 'spisok', (5-9j)]
|
|
>>> stup=[0,0,1,1,1,1,1,1,1]
|
|
>>> stup
|
|
[0, 0, 1, 1, 1, 1, 1, 1, 1]
|
|
>>> spis = [1,2,3,4,
|
|
5,6,7,8,
|
|
9,10]
|
|
>>> spis
|
|
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
|
|
```
|
|
Также по индексу можно сослаться на определенные элементы. Или перечислить с некоторым шагом.
|
|
|
|
```py
|
|
>>> spis[-1]
|
|
10
|
|
>>> stup[-8::2]
|
|
[0, 1, 1, 1]
|
|
>>> spis[-9::2]
|
|
[2, 4, 6, 8, 10]
|
|
```
|
|
|
|
Списки можно изменять, меняя элементы и переписывая их.
|
|
|
|
```py
|
|
>>> spis1[1] = 'Список'
|
|
>>> spis1
|
|
[111, 'Список', (5-9j)]
|
|
```
|
|
|
|
len(...) возвращает длину списка(количестево элементов в контейнере)
|
|
spis1.append(элемент) добавляет элемент в конец списка
|
|
spis1+[элемент] - добавляет элемент на вывод 1 раз. Не вписывает этот элемент в список
|
|
spis1.pop(индекс элемента) - удаляет элемент с указанным индексом
|
|
spis1.reverse - переворачивает список
|
|
spis1.insert(индекс, элемент) - вставляет элемент после элемента с указанным индексом
|
|
spis1.extend(список) - присоединяет в конец другой список
|
|
spis1.remove(элемент) - удаляет первый встреченный элемент равный указанному
|
|
spis1.sort() - сортирует список в порядке возрастания
|
|
spis1.copy() - создает поверхностную копию(shallow copy)
|
|
spis1.index(элемент) - возвращает индекс первого соответсвующего элемента
|
|
spis1.clear() - очищает список
|
|
spis1.count(элемент) - считает кол-во соответствующих элементов
|
|
|
|
```py
|
|
>>> len(spis)
|
|
10
|
|
>>> 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')
|
|
>>> spis1
|
|
[111, 'Список', (5-9j), 'New item']
|
|
>>> spis1+['Newest item']
|
|
[111, 'Список', (5-9j), 'New item', 'Newest item']
|
|
>>> spis1
|
|
[111, 'Список', (5-9j), 'New item']
|
|
>>> spis1.append(ss1b)
|
|
>>> spis1
|
|
[111, 'Список', (5-9j), 'New item', 'my name is: \n Savin S.A.']
|
|
>>> spis1.pop(1)
|
|
'Список'
|
|
>>> spis1
|
|
[111, (5-9j), 'New item', 'my name is: \n Savin S.A.']
|
|
>>> spis1.reverse
|
|
<built-in method reverse of list object at 0x000001D8904F0C80>
|
|
>>> spis1
|
|
[111, (5-9j), 'New item', 'my name is: \n Savin S.A.']
|
|
>>> spis1.reverse()
|
|
>>> spis1
|
|
['my name is: \n Savin S.A.', 'New item', (5-9j), 111]
|
|
>>> spis1.insert(2, 2+ 2j)
|
|
>>> spis1
|
|
['my name is: \n Savin S.A.', 'New item', (2+2j), (5-9j), 111]
|
|
>>> spis1.extend(spis)
|
|
>>> spis1
|
|
['my name is: \n Savin S.A.', 'New item', (2+2j), (5-9j), 111, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
|
|
>>> spis1.append('New item')
|
|
>>> spis1
|
|
['my name is: \n Savin S.A.', 'New item', (2+2j), (5-9j), 111, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 'New item']
|
|
>>> spis1.remove('New item')
|
|
>>> spis1
|
|
['my name is: \n Savin S.A.', (2+2j), (5-9j), 111, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 'New item']
|
|
>>> spis1.count(1)
|
|
1
|
|
>>> spis1.index(10)
|
|
13
|
|
>>> spis.clear()
|
|
>>> spis1.clear()
|
|
>>> spis1
|
|
[]
|
|
>>> spis
|
|
[]
|
|
```
|
|
|
|
Далее создаем вложенные списки. Здесь я также попробовал применить spis2.copy() и проверить как работает поверхностная копия.
|
|
В итоге сделан вывод - изменения в копии не вносятся только на первом уровне. Если поменять вложенный список, то он поменяется и для оригинала.
|
|
Тут же я самостоятельно изменил вложенный элемент при помощи append. После изменил значения элемента во вложенном списке.
|
|
|
|
```py
|
|
>>> spis1 = (1,2,3)
|
|
>>> spis1 = [1,2,3]
|
|
>>> spis1
|
|
[1, 2, 3]
|
|
>>> spis2 = [spis1,[4,5,6,7]]
|
|
>>> spis2
|
|
[[1, 2, 3], [4, 5, 6, 7]]
|
|
>>> copytest = spis2.copy()
|
|
>>> copytest
|
|
[[1, 2, 3], [4, 5, 6, 7]]
|
|
>>> spis2
|
|
[[1, 2, 3], [4, 5, 6, 7]]
|
|
>>> copytest.append(3)
|
|
>>> copytest
|
|
[[1, 2, 3], [4, 5, 6, 7], 3]
|
|
>>> spis2
|
|
[[1, 2, 3], [4, 5, 6, 7]]
|
|
>>> copytest
|
|
[[1, 2, 3], [4, 5, 6, 7], 3]
|
|
>>> copytest[1].append(2)
|
|
>>> copytest
|
|
[[1, 2, 3], [4, 5, 6, 7, 2], 3]
|
|
>>> spis2
|
|
[[1, 2, 3], [4, 5, 6, 7, 2]]
|
|
>>> spis2
|
|
[[1, 2, 3], [4, 5, 6, 7, 2]]
|
|
>>> spis2[0] = 78
|
|
>>> spis2
|
|
[78, [4, 5, 6, 7, 2]]
|
|
```
|
|
|
|
## 8.2. Кортеж
|
|
|
|
Работа с кортежами - их нельзя изменять, но можно переопределять, таким образом внося изменения.
|
|
|
|
```py
|
|
>>> 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, 'my name is: \n Savin S.A.')
|
|
>>> kort2 = kort1[:2] + kort1[3:]
|
|
>>> kort2
|
|
(222, 'Kortezh', 1, 2, 'my name is: \n Savin S.A.')
|
|
>>> kort2.index(2)
|
|
3
|
|
>>> kort2.count(222)
|
|
1
|
|
>>> kort2[2] = 90
|
|
Traceback (most recent call last):
|
|
File "<pyshell#227>", line 1, in <module>
|
|
kort2[2] = 90
|
|
TypeError: 'tuple' object does not support item assignment
|
|
```
|
|
|
|
## 8.3. Словарь
|
|
|
|
Работа со словарями. Ключи - неизменяемы.
|
|
|
|
```py
|
|
>>> 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]
|
|
>>> dic1
|
|
{'Saratov': 145, 'Orel': 56, 'Vologda': 45, 'Pskov': 78}
|
|
>>> 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': 'my name is: \n Savin S.A.'}
|
|
>>> dic5 = dict(zip(['A','B','C','Stroka'],[16,-3,9,ss1b]))
|
|
>>> dic5
|
|
{'A': 16, 'B': -3, 'C': 9, 'Stroka': 'my name is: \n Savin S.A.'}
|
|
```
|
|
|
|
Свой словарь состоит из 5 элементов, потому что мы "сшили" два контейнера, длина определилась по минимальному кол-ву.
|
|
|
|
```py
|
|
>>> testkort = ('B','S','M','H','D','A','R')
|
|
>>> testlist = ['bow','sword','mace','helbard','dirk']
|
|
>>> dictest=dict(zip(testkort,testlist))
|
|
>>> dictest
|
|
{'B': 'bow', 'S': 'sword', 'M': 'mace', 'H': 'helbard', 'D': 'dirk'}
|
|
```
|
|
## 8.4. Множество
|
|
|
|
Множества могут состоять только из неповторяющихся неизменяемых элементов - при создании множества со списком выведет ошибку.
|
|
|
|
```py
|
|
>>> mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'}
|
|
>>> mnoz1
|
|
{'линия связи', 'датчик', 'микропроцессор', 'двигатель'}
|
|
>>> len(mnoz1)
|
|
4
|
|
>>> 'датчик' in mnoz1
|
|
True
|
|
>>> mnoz1.add('htkt')
|
|
>>> mnoz1.remove('htkt')
|
|
>>> mnoz1.add('реле')
|
|
>>> mnoz1
|
|
{'датчик', 'двигатель', 'микропроцессор', 'линия связи', 'реле'}
|
|
>>> mnoz1.remove('линия связи')
|
|
>>> mnoz1
|
|
{'датчик', 'двигатель', 'микропроцессор', 'реле'}
|
|
>>> mnoz2 = {'дерево', 15, 78, [6,7,8]}
|
|
Traceback (most recent call last):
|
|
File "<pyshell#268>", line 1, in <module>
|
|
mnoz2 = {'дерево', 15, 78, [6,7,8]}
|
|
TypeError: unhashable type: 'list'
|
|
>>> kortmnoz = (7,8,7,8)
|
|
>>> mnoz2 = {'дерево', 16, 19, kortmnoz}
|
|
>>> mnoz2
|
|
{16, (7, 8, 7, 8), 19, 'дерево'}
|
|
>>> mnoz2.add(kort1)
|
|
>>> mnoz2
|
|
{(222, 'Kortezh', (77+8j), 1, 2, 'my name is: \n Savin S.A.'), 16, (7, 8, 7, 8), 19, 'дерево'}
|
|
>>> mnoz2.remove('дерево')
|
|
>>> mnoz2
|
|
{(222, 'Kortezh', (77+8j), 1, 2, 'my name is: \n Savin S.A.'), 16, (7, 8, 7, 8), 19}
|
|
>>> len(mnoz2)
|
|
4
|
|
```
|
|
|
|
# Общее контрольное задаие по теме 2
|
|
|
|
Савин Семён, А-02-23
|
|
|
|
## Задание
|
|
|
|
1) Создать переменную с именем familia и со значением - символьной строкой – своей фамилией в латинской транскрипции.
|
|
2) Создать переменную со значением, совпадающим с первой буквой из familia.
|
|
3) Создать переменную с именем sp_kw со значением – списком всей ключевых слов языка Python.
|
|
4) Удалите из списка sp_kw значение 'nonlocal'. Выводом списка в командном окне IDLE убедитесь, что это значение удалено из списка.
|
|
5) Создайте кортеж kort_nam с именами: вашим и еще 3-х студентов из вашей группы. Напишите инструкцию, позволяющую убедиться, что тип переменной – это tuple.
|
|
6) Напишите инструкцию, добавляющую в kort_nam имена еще двух студентов.
|
|
7) Напишите инструкцию, позволяющую определить, сколько раз в кортеже присутствуют студенты с именем «Дима».
|
|
8) Создайте словарь dict_bas, в котором ключами являются русские названия типов переменных, использованных в предыдущих операторах, а значениями – ранее созданные переменные, соответствующие этим типам.
|
|
|
|
## Решение
|
|
|
|
```py
|
|
>>> familia = 'Savin'
|
|
>>> familia
|
|
'Savin'
|
|
>>> bukva = familia[0]
|
|
>>> bukva
|
|
'S'
|
|
>>> sp_kv = keyword.kwlist
|
|
>>> sp_kv
|
|
['False', 'None', 'True', '__peg_parser__', '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_kv.remove('nonlocal')
|
|
>>> sp_kv
|
|
['False', 'None', 'True', '__peg_parser__', '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_nam = ('Семён', 'Ярослав', 'Миша')
|
|
>>> type(kort_nam)
|
|
<class 'tuple'>
|
|
>>> kort_nam.count('Дима')
|
|
0
|
|
>>> dict_bas = {'Строка': [familia,bukva], 'Список': sp_kv, 'Кортеж': kort_nam}
|
|
>>> dict_bas
|
|
{'Строка': ['Savin', 'S'], 'Список': ['False', 'None', 'True', '__peg_parser__', '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'], 'Кортеж': ('Семён', 'Ярослав', 'Миша')}
|
|
|
|
```
|
|
|
|
Для работы со строкой использовал ссылку по индексу, отпечатал первую букву.
|
|
Для работы со списком присвоил значению sp_kv keyword.kwlist - это уже список, поэтому без []
|
|
В кортеж не записано имен "Дима", kort_nam.count('Дима') выводит 0
|
|
Внес в словарь две строки, перед эти объединив их в список - одному ключу одно значение.
|