форкнуто от main/python-labs
Вы не можете выбрать более 25 тем
Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
362 строки
14 KiB
Markdown
362 строки
14 KiB
Markdown
# Отчет по теме 2
|
|
|
|
Коломейцев Дмитрий, А-02-23
|
|
|
|
## Тема 2. Базовые типы объектов
|
|
|
|
## 1-2. Изучение простых объектов
|
|
|
|
Создали переменные f1 и f2, затем получили список атрибутов среды и каждой переменной отдельно командой dir():
|
|
|
|
```py
|
|
|
|
f1=16
|
|
f2=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']
|
|
dir(f2)
|
|
['__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():
|
|
```py
|
|
type(f1)
|
|
<class 'int'>
|
|
type(f2)
|
|
<class 'int'>
|
|
```
|
|
|
|
Удалим переменные командой del var1, var2, ...:
|
|
|
|
```py
|
|
del f1, f2
|
|
dir()
|
|
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__']
|
|
```
|
|
|
|
## 3. Правила именования объектов в Python
|
|
- Имена должны состоять из латинских букв, цифр и символов подчеркивания;
|
|
- Имена должны начинаться с латинской буквы (иногда могут начинаться с символа подчеркивания, но это – особый вид переменных);
|
|
- Имена не должны совпадать с ключевыми словами и встроенными идентификаторами языка Python;
|
|
- Большие и малые буквы в именах различаются (имена – чувствительные к регистру)!
|
|
|
|
|
|
```py
|
|
gg1=1.6
|
|
hh1='Строка'
|
|
73sr=3
|
|
SyntaxError: invalid decimal literal
|
|
and=7
|
|
SyntaxError: invalid syntax
|
|
```
|
|
|
|
## 4. Вывод списка ключевых слов
|
|
|
|
Просмотрел список ключевых слов Python и записал их в переменную keyword_array.
|
|
|
|
```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']
|
|
keyword_array = keyword.kwlist
|
|
keyword_array
|
|
['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. Вывод списка встроенных идентификаторов и изучение функций
|
|
|
|
```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(-7)
|
|
7
|
|
# Длина объекта
|
|
len("Привет, мир!")
|
|
11
|
|
|
|
# Максимально число
|
|
max([5, 12, 3])
|
|
12
|
|
|
|
# Минимальное число
|
|
min(4, 9, 1)
|
|
1
|
|
|
|
# Степень числа pow(число, степень)
|
|
pow(2, 5)
|
|
32
|
|
|
|
# Округление до n знаков после запятой
|
|
round(3.14159, 2)
|
|
3.14
|
|
|
|
# Сортировка массива с параметрами (по возрастанию, по убыванию и т.д.)
|
|
sorted([3, 1, 2, 5])
|
|
[1, 2, 3, 5]
|
|
|
|
sorted([3, 1, 2, 5], reverse=True)
|
|
[5, 3, 2, 1]
|
|
|
|
# Сумма чисел
|
|
sum([10, 20, 30])
|
|
60
|
|
|
|
# Создаёт пары сопоставляя элементы 1 массива элементам 2 массива
|
|
zip([1, 2, 3], ['a', 'b', 'c'])
|
|
[(1, 'a'), (2, 'b'), (3, 'c')]
|
|
```
|
|
|
|
## 6. Вывод переменных с разным регистром
|
|
|
|
Вывел 2 переменные с одинаковым названием, но с разным регистром - значения разные:
|
|
|
|
```py
|
|
Gg1=45
|
|
gg1
|
|
1.6
|
|
Gg1
|
|
45
|
|
```
|
|
## 7. Изучение простых базовых типов: bool, int, float, complex, str
|
|
|
|
Логический тип хранит 2 типа значений: true и false.
|
|
|
|
### 7.1 Логический тип
|
|
```py
|
|
bb1=True; bb2=False
|
|
|
|
bb1;bb2
|
|
True
|
|
False
|
|
|
|
type(bb1)
|
|
<class 'bool'>
|
|
```
|
|
|
|
|
|
### 7.2 Другие простые типы
|
|
|
|
```py
|
|
# Целый тип int
|
|
ii1=-1234567890
|
|
ii1
|
|
-1234567890
|
|
|
|
# Вещественный тип float
|
|
ff1=-8.9876e-12
|
|
ff1
|
|
-8.9876e-12
|
|
|
|
# Тип int, но двоичная запись
|
|
dv1=0b1101010
|
|
dv1
|
|
106
|
|
|
|
# Тип int, но восьмеричная запись
|
|
vsm1=0o52765
|
|
vsm1
|
|
22005
|
|
|
|
# Тип int, но шестнадцатеричная запись
|
|
shest1=0x7109af6
|
|
shest1
|
|
118528758
|
|
|
|
# Тип complex комплексных чисел
|
|
cc1=2-3j
|
|
cc1
|
|
(2-3j)
|
|
|
|
# Создание комплексной переменной из 2 int
|
|
a=3.67; b=-0.45
|
|
|
|
a;b
|
|
3.67
|
|
-0.45
|
|
|
|
cc2=complex(a,b)
|
|
cc2
|
|
(3.67-0.45j)
|
|
```
|
|
|
|
### 7.3 Строковый тип (str)
|
|
|
|
```py
|
|
ss1='Это - строка символов'
|
|
|
|
ss1a="Это - \" строка символов \", \n \t выводимая на двух строках"
|
|
|
|
mnogo="""Нетрудно заметить , что в результате операции
|
|
над числами разных типов получается число,
|
|
имеющее более сложный тип из тех, которые участвуют в операции."""
|
|
|
|
# Индексирование и срезы строк
|
|
ss1[0]
|
|
'Э'
|
|
ss1[8]
|
|
'р'
|
|
ss1[-2]
|
|
'о'
|
|
ss1[6:9]
|
|
'стр'
|
|
ss1[13:]
|
|
'символов'
|
|
ss1[:13]
|
|
'Это - строка '
|
|
ss1[5:-8]
|
|
' строка '
|
|
ss1[3:17:2]
|
|
' тоасм'
|
|
ss1[17:3:-2]
|
|
'омсаот '
|
|
|
|
ss1b= 'Меня зовут: \n Коломейцев Д.А.'
|
|
ss1b
|
|
'Меня зовут: \n Коломейцев Д.А.'
|
|
|
|
```
|
|
|
|
Изучил операции со строками:
|
|
|
|
```py
|
|
# Конкатенация строк (соединение)
|
|
ss1="Привет"
|
|
ss14=" мир"
|
|
ss15=ss1+ss14
|
|
print(ss1+'b') # конкатенация с символом
|
|
```
|
|
|
|
## 8 Изучение составных типов данных: list, tuple, dict, set
|
|
|
|
### 8.1 Списки (list)
|
|
|
|
Списки - упорядоченные коллекции объектов произвольных типов, которые можно изменять.
|
|
|
|
```py
|
|
# Создание списков
|
|
spis1=[111,"Spisok",5-9j]
|
|
stup0=(0,0,1,1,1,1,1,1,1)
|
|
spis1=[1,2,3,4, 5,6,7, 8,9,10]
|
|
|
|
# Индексирование
|
|
print(spis1[-1]) # последний элемент
|
|
10
|
|
print(stup0[-8:2]) # срез кортежа
|
|
(0, 0)
|
|
|
|
# Изменение списка
|
|
spis1[1]=spis1
|
|
print(len(spis1)) # длина списка
|
|
10
|
|
|
|
# Методы списков
|
|
spis1.append("New item") # добавление элемента
|
|
print("New item" in spis1) # проверка наличия элемента
|
|
True
|
|
|
|
spis1.pop(1) # удаление элемента по индексу
|
|
# Другие методы:
|
|
# list.insert(i, x) - вставляет на i-тую позицию элемент x
|
|
# list.remove(x) - удаляет первый элемент в списке со значением x
|
|
# list.extend(L) - расширяет список list, добавляя в конец все элементы списка L
|
|
```
|
|
|
|
### 8.2 Кортежи (tuple)
|
|
|
|
Главное отличие кортежей от списков - их нельзя изменять после создания.
|
|
|
|
```py
|
|
# Создание кортежей
|
|
kort1=(222,"Kortezh",7+7.8j)
|
|
print(kort1[1:2])
|
|
('Kortezh',)
|
|
|
|
# Методы кортежей
|
|
# Все методы списков, не изменяющие список
|
|
kort1.index(222) # поиск индекса элемента
|
|
0
|
|
kort1.count(222) # подсчет вхождений
|
|
1
|
|
|
|
```
|
|
|
|
### 8.3 Словари (dict)
|
|
|
|
Словари в Python - неупорядоченные коллекции произвольных объектов с доступом по ключу. Каждому ключу сопоставляется значение. Ключами могут быть только неизменяемые типы.
|
|
|
|
```py
|
|
# Создание словарей
|
|
dic1={"Saratov":145, "Orel":56, "Vologda":45}
|
|
print(dic1["Orel"])
|
|
56
|
|
|
|
d = {}
|
|
d
|
|
{}
|
|
|
|
d = {'dict': 1, 'dictionary': 2}
|
|
d
|
|
{'dict': 1, 'dictionary': 2}
|
|
|
|
# Добавление элементов
|
|
dic1["Pskov"]=78
|
|
print(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"}
|
|
print(dic3["statistics"][2])
|
|
standart deviation
|
|
|
|
# Другие методы:
|
|
# dict.clear() - очищает словарь.
|
|
# dict.copy() - возвращает копию словаря.
|
|
# dict.get(key[, default]) - возвращает значение ключа, но если его нет, не бросает исключение, а возвращает default (по умолчанию None).
|
|
|
|
# dict.items() - возвращает пары (ключ, значение).
|
|
|
|
```
|
|
|
|
### 8.4 Множества (set)
|
|
|
|
Объект-множество – это неупорядоченная совокупность неповторяющихся (уникальных) элементов. Эти элементы могут быть разных, но только неизменяемых типов (числа, строки, кортежи).
|
|
|
|
|
|
```py
|
|
# Создание множеств
|
|
mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'}
|
|
|
|
mnoz1
|
|
{'двигатель', 'микропроцессор', 'линия связи', 'датчик'}
|
|
|
|
len(mnoz1)
|
|
4
|
|
|
|
# Методы множеств
|
|
'датчик' in mnoz1 # проверка принадлежности
|
|
True
|
|
mnoz1.add('реле') # добавление элемента
|
|
mnoz1
|
|
{'датчик', 'реле', 'двигатель', 'микропроцессор', 'линия связи'}
|
|
mnoz1.remove('линия связи') # удаление элемента
|
|
mnoz1
|
|
{'датчик', 'реле', 'двигатель', 'микропроцессор'}
|
|
```
|
|
|
|
## 9 Завершение работы.
|