Dmitry Kolomeytsev 4 недель назад
Родитель ada602dc5d
Сommit 98c75780a2

@ -0,0 +1,361 @@
# Отчет по теме 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 Завершение работы.

@ -0,0 +1,15 @@
# Индивидуальное контрольное задание по теме 1
Коломейцев Дмитрий, А-02-23
## Вопрос
Как можно запустить на выполнение программу, исходный код которой находится в текстовом файле ABC.txt?
## Ответ
В IDLE открыть файл "ABC.txt" в новом окне, затем запустить с помощью Run Module. Код запускается исправно даже из .txt
![alt text]({F7D7B2E4-76E6-4F38-9C43-470D24B73207}.png)
![alt text]({B972A96F-678A-40AB-BAFF-18C9F80851E2}.png)
Загрузка…
Отмена
Сохранить