форкнуто от main/python-labs
Вы не можете выбрать более 25 тем
Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
499 строки
15 KiB
Markdown
499 строки
15 KiB
Markdown
# Отчет по теме 2
|
|
|
|
Васильев Илья А-03-23
|
|
|
|
## 1 Запуск
|
|
|
|
## 2 Изучение простых объектов
|
|
|
|
```py
|
|
f1=16; f2=3
|
|
f1,f2
|
|
(16, 3)
|
|
f1;f2
|
|
16
|
|
3
|
|
```
|
|
```py
|
|
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']
|
|
```
|
|
|
|
```py
|
|
del f1,f2
|
|
dir()
|
|
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__']
|
|
```
|
|
|
|
## 3 Изучение правил наименования объектов
|
|
|
|
```py
|
|
gg1=1.6
|
|
hh1='Строка'
|
|
73sr=3
|
|
SyntaxError: invalid syntax
|
|
and=7
|
|
SyntaxError: invalid syntax
|
|
```
|
|
|
|
## 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']
|
|
keylist = keyword.kwlist
|
|
```
|
|
|
|
## Вывод списка встроенных идентификаторов
|
|
|
|
```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(-3)
|
|
3
|
|
max(3, 2, 9)
|
|
9
|
|
round(3.6)
|
|
4
|
|
a='bibibibi'
|
|
len(a)
|
|
8
|
|
```
|
|
|
|
## 6 Изучение зависимости от заглавной буквы
|
|
|
|
```py
|
|
Gg1=45
|
|
gg1
|
|
1.6
|
|
Gg1
|
|
45
|
|
```
|
|
|
|
## 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
|
|
type(vsm1)
|
|
<class 'int'>
|
|
shest1=0x7109af6
|
|
type(shest1)
|
|
<class 'int'>
|
|
cc1=2-3j
|
|
type(cc1)
|
|
<class 'complex'>
|
|
a=3.67; b=-0.45
|
|
cc2=complex(a,b)
|
|
type(cc2)
|
|
<class 'complex'>
|
|
```
|
|
|
|
## 7.3 Строка символов
|
|
|
|
```py
|
|
ss1a="Это - \" строка символов \", \n \t выводимая на двух строках"
|
|
print(ss1a)
|
|
Это - " строка символов ",
|
|
выводимая на двух строках
|
|
```
|
|
|
|
```py
|
|
ss1b= 'Меня зовут: \n Илья'
|
|
print(ss1b)
|
|
Меня зовут:
|
|
Илья
|
|
```
|
|
```py
|
|
mnogo="""Нетрудно заметить , что в результате операции
|
|
над числами разных типов получается число,
|
|
имеющее более сложный тип из тех, которые участвуют в операции."""
|
|
|
|
print(mnogo)
|
|
Нетрудно заметить , что в результате операции
|
|
над числами разных типов получается число,
|
|
имеющее более сложный тип из тех, которые участвуют в операции.
|
|
```
|
|
|
|
```py
|
|
ss1[0]
|
|
'Э'
|
|
ss1[8]
|
|
'р'
|
|
ss1[-2]
|
|
'о'
|
|
ss1[6:9]
|
|
'стр'
|
|
ss1[13:]
|
|
'символов'
|
|
ss1[:13]
|
|
'Это - строка '
|
|
ss1[5:-8]
|
|
' строка '
|
|
ss1[3:17:2]
|
|
' тоасм'
|
|
ss1[17:3:-2]
|
|
'омсаот '
|
|
ss1[-4:3:-2]
|
|
'омсаот '
|
|
```
|
|
|
|
```py
|
|
ss1[4]='='
|
|
```
|
|
|
|
```py
|
|
ss1=ss1[:4]+'='+ss1[5:]
|
|
print(ss1)
|
|
Это = строка символов
|
|
```
|
|
|
|
Работа со строкой
|
|
|
|
```py
|
|
ss1b=ss1b[:6]
|
|
print(ss1b)
|
|
Меня з
|
|
ss1b=ss1b[:3]+ss1b[4:]*2
|
|
print(ss1b)
|
|
Мен з з
|
|
```
|
|
## Изучение более сложных типов объектов
|
|
|
|
## 8.1 Список
|
|
|
|
```py
|
|
spis1=[111,'Spisok',5-9j]
|
|
print(spis1)
|
|
[111, 'Spisok', (5-9j)]
|
|
```
|
|
|
|
```py
|
|
stup=[0,0,1,1,1,1,1,1,1]
|
|
print(stup)
|
|
[0, 0, 1, 1, 1, 1, 1, 1, 1]
|
|
```
|
|
|
|
```py
|
|
spis=[1,2,3,4,
|
|
5,6,7,
|
|
8,9,10]
|
|
print(spis)
|
|
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
|
|
```
|
|
|
|
Индексы
|
|
```py
|
|
spis1[-1]
|
|
(5-9j)
|
|
stup[-8::2]
|
|
[0, 1, 1, 1]
|
|
```
|
|
Изменение списка
|
|
|
|
```py
|
|
spis1[1]='Список'
|
|
print(spis1)
|
|
[111, 'Список', (5-9j)]
|
|
```
|
|
|
|
Длина списка
|
|
|
|
```py
|
|
len(spis1)
|
|
3
|
|
```
|
|
|
|
Добавление в Список
|
|
|
|
```py
|
|
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')
|
|
print(spis1)
|
|
[111, 'Список', (5-9j), 'New item']
|
|
```
|
|
|
|
```py
|
|
spis1+['New item']
|
|
[111, 'Список', (5-9j), 'New item', 'New item']
|
|
```
|
|
|
|
```py
|
|
spis1.append(ss1b)
|
|
print(spis1)
|
|
[111, 'Список', (5-9j), 'New item', 'Менз з']
|
|
```
|
|
|
|
Удаление элемента
|
|
|
|
```py
|
|
spis1.pop(1)
|
|
'Список'
|
|
```
|
|
|
|
```py
|
|
spis1.reverse
|
|
<built-in method reverse of list object at 0x00000239E7AB1A40>
|
|
spis1
|
|
[111, (5-9j), 'New item', 'Менз з']
|
|
spis1.reverse()
|
|
spis1
|
|
['Менз з', 'New item', (5-9j), 111]
|
|
```
|
|
|
|
```py
|
|
spis1.extend(spis)
|
|
spis1
|
|
['Менз з', 'New item', (5-9j), 111, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
|
|
```
|
|
|
|
Вложенные списки
|
|
|
|
```py
|
|
spis2=[spis1,[4,5,6,7]]
|
|
spis2
|
|
[['Менз з', 'New item', (5-9j), 111, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10], [4, 5, 6, 7]]
|
|
```
|
|
|
|
Обращение к элементу списка
|
|
```py
|
|
spis2[0][1]
|
|
'New item'
|
|
```
|
|
|
|
Изменение элемента списка
|
|
|
|
```py
|
|
spis2[0][1]=78
|
|
spis2
|
|
[['Менз з', 78, (5-9j), 111, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10], [4, 5, 6, 7]]
|
|
spis1
|
|
['Менз з', 78, (5-9j), 111, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
|
|
```
|
|
если менять элемент во вложенном списке то поменяется и основной
|
|
|
|
Создан список с разным типом элементов
|
|
|
|
```py
|
|
list = ['aaaa', 11, True, ['a','b','c','d']]
|
|
list
|
|
['aaaa', 11, True, ['a', 'b', 'c', 'd']]
|
|
```
|
|
|
|
## Кортеж
|
|
|
|
Создание кортежа
|
|
|
|
```py
|
|
kort1=(222,'Kortezh',77+8j)
|
|
print(kort1)
|
|
(222, 'Kortezh', (77+8j))
|
|
```
|
|
|
|
Переопределение
|
|
|
|
```py
|
|
kort1= kort1+(1,2)
|
|
print(kort1)
|
|
(222, 'Kortezh', (77+8j), 1, 2)
|
|
```
|
|
|
|
Добавление элемента
|
|
```py
|
|
kort1= kort1+(ss1b,)
|
|
kort1
|
|
(222, 'Kortezh', (77+8j), 1, 2, 'Менз з')
|
|
```
|
|
|
|
Переопределение с удалением комплексного элемента
|
|
|
|
```py
|
|
kort2=kort1[:2]+kort1[3:]
|
|
kort2
|
|
(222, 'Kortezh', 1, 2, 'Менз з')
|
|
```
|
|
|
|
Индекс заданного элемента
|
|
|
|
```py
|
|
kort1.index(2)
|
|
4
|
|
```
|
|
|
|
Число вхождений элемента
|
|
|
|
```py
|
|
kort1[2]=90
|
|
```
|
|
|
|
Неизменяемость кортежа
|
|
|
|
```py
|
|
kort1[2]=90
|
|
Traceback (most recent call last):
|
|
File "<pyshell#139>", line 1, in <module>
|
|
kort1[2]=90
|
|
TypeError: 'tuple' object does not support item assignment
|
|
```
|
|
|
|
## Словарь
|
|
|
|
Создание словаря
|
|
|
|
```py
|
|
dic1={'Saratov':145, 'Orel':56, 'Vologda':45}
|
|
```
|
|
|
|
Обращение к элементам словаря
|
|
|
|
```py
|
|
dic1['Orel']
|
|
56
|
|
```
|
|
|
|
Пополнение словаря
|
|
|
|
```py
|
|
dic1['Pskov']=78
|
|
dic1
|
|
{'Saratov': 145, 'Orel': 56, 'Vologda': 45, 'Pskov': 78}
|
|
```
|
|
|
|
Сортировка
|
|
|
|
```py
|
|
sorted(dic1.keys())
|
|
['Orel', 'Pskov', 'Saratov', 'Vologda']
|
|
sorted(dic1.values())
|
|
[45, 56, 78, 145]
|
|
```
|
|
|
|
Элементы словаря
|
|
|
|
```py
|
|
dic2={1:'mean',2:'standart deviation',3:'correlation'}
|
|
dic3={'statistics':dic2,'POAS':['base','elementary','programming']}
|
|
dic3['statistics'][2]
|
|
'standart deviation'
|
|
dic2
|
|
{1: 'mean', 2: 'standart deviation', 3: 'correlation'}
|
|
dic3
|
|
{'statistics': {1: 'mean', 2: 'standart deviation', 3: 'correlation'}, 'POAS': ['base', 'elementary', 'programming']}
|
|
dic4=dict([(1,['A','B','C']),(2,[4,5]),('Q','Prim'),('Stroka',ss1b)])
|
|
dic4
|
|
{1: ['A', 'B', 'C'], 2: [4, 5], 'Q': 'Prim', 'Stroka': 'Менз з'}
|
|
dic5=dict(zip(['A','B','C','Stroka'],[16,-3,9,ss1b]))
|
|
dic5
|
|
{'A': 16, 'B': -3, 'C': 9, 'Stroka': 'Менз з'}
|
|
```
|
|
|
|
Создание словаря
|
|
|
|
```py
|
|
allah = {'A', 'B', 'C', 'D', 'E', 'F', 'J'}
|
|
jesus = {'ability', 'bowl', 'condom', 'durex', 'elephant'}
|
|
dictionary= dict(zip(allah, jesus))
|
|
dictionary
|
|
{'C': 'ability', 'B': 'durex', 'F': 'elephant', 'A': 'bowl', 'J': 'condom'}
|
|
```
|
|
Количество элементов определилось по меньшему размеру из них
|
|
|
|
## Множество
|
|
|
|
Создание множества
|
|
|
|
```py
|
|
mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'}
|
|
mnoz1
|
|
{'двигатель', 'датчик', 'микропроцессор', 'линия связи'}
|
|
```
|
|
|
|
Операции над множеством
|
|
|
|
```py
|
|
len(mnoz1)
|
|
4
|
|
'датчик' in mnoz1
|
|
True
|
|
mnoz1.add('реле')
|
|
mnoz1
|
|
{'реле', 'двигатель', 'линия связи', 'датчик', 'микропроцессор'}
|
|
mnoz1.remove('линия связи')
|
|
```
|
|
|
|
## Общее контрольное задание по теме 2
|
|
|
|
Васильев И.Н. А-03-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 = 'Vasilev'
|
|
familia
|
|
'Vasilev'
|
|
firstletter=familia[0]
|
|
firstletter
|
|
'V'
|
|
sp_kv = keyword.kwlist
|
|
sp_kv
|
|
['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_kv.remove('nonlocal')
|
|
sp_kv
|
|
['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_nam = ('Ilia', 'Dmitry', 'Muhammed')
|
|
type(kort_nam)
|
|
<class 'tuple'>
|
|
adding=('Mustafa', 'Bob')
|
|
kort_nam=kort_nam+adding
|
|
kort_nam
|
|
('Ilia', 'Dmitry', 'Muhammed', 'Mustafa', 'Bob')
|
|
kort_nam.count('Dmitry')
|
|
1
|
|
dict_bas={'Строка': [familia,firstletter], 'Список': sp_kv, 'Кортеж': kort_nam}
|
|
dict_bas
|
|
{'Строка': ['Vasilev', 'V'], 'Список': ['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'], 'Кортеж': ('Ilia', 'Dmitry', 'Muhammed', 'Mustafa', 'Bob')} |