Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

14 KiB

Отчет по теме 2

Коломейцев Дмитрий, А-02-23

Тема 2. Базовые типы объектов

1-2. Изучение простых объектов

Создали переменные f1 и f2, затем получили список атрибутов среды и каждой переменной отдельно командой dir():


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():

type(f1)
<class 'int'>
type(f2)
<class 'int'>

Удалим переменные командой del var1, var2, ...:

del f1, f2
dir()
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__']

3. Правила именования объектов в Python

  • Имена должны состоять из латинских букв, цифр и символов подчеркивания;
  • Имена должны начинаться с латинской буквы (иногда могут начинаться с символа подчеркивания, но это – особый вид переменных);
  • Имена не должны совпадать с ключевыми словами и встроенными идентификаторами языка Python;
  • Большие и малые буквы в именах различаются (имена – чувствительные к регистру)!
gg1=1.6
hh1='Строка'
73sr=3
SyntaxError: invalid decimal literal
and=7
SyntaxError: invalid syntax

4. Вывод списка ключевых слов

Просмотрел список ключевых слов Python и записал их в переменную keyword_array.

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. Вывод списка встроенных идентификаторов и изучение функций

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']

Изучил назначение математических функций с примерами:

# Модуль числа
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 переменные с одинаковым названием, но с разным регистром - значения разные:

Gg1=45
gg1
1.6
Gg1
45

7. Изучение простых базовых типов: bool, int, float, complex, str

Логический тип хранит 2 типа значений: true и false.

7.1 Логический тип

bb1=True; bb2=False

bb1;bb2
True
False

type(bb1)
<class 'bool'>

7.2 Другие простые типы

# Целый тип 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)

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 Коломейцев Д.А.'

Изучил операции со строками:

# Конкатенация строк (соединение)
ss1="Привет"
ss14=" мир"
ss15=ss1+ss14
print(ss1+'b')  # конкатенация с символом

8 Изучение составных типов данных: list, tuple, dict, set

8.1 Списки (list)

Списки - упорядоченные коллекции объектов произвольных типов, которые можно изменять.

# Создание списков
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)

Главное отличие кортежей от списков - их нельзя изменять после создания.

# Создание кортежей
kort1=(222,"Kortezh",7+7.8j)
print(kort1[1:2])
('Kortezh',)

# Методы кортежей
# Все методы списков, не изменяющие список
kort1.index(222)  # поиск индекса элемента
0
kort1.count(222)  # подсчет вхождений
1

8.3 Словари (dict)

Словари в Python - неупорядоченные коллекции произвольных объектов с доступом по ключу. Каждому ключу сопоставляется значение. Ключами могут быть только неизменяемые типы.

# Создание словарей
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)

Объект-множество – это неупорядоченная совокупность неповторяющихся (уникальных) элементов. Эти элементы могут быть разных, но только неизменяемых типов (числа, строки, кортежи).

# Создание множеств
mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'}

mnoz1
{'двигатель', 'микропроцессор', 'линия связи', 'датчик'}

len(mnoz1)
4

# Методы множеств
'датчик' in mnoz1 # проверка принадлежности
True
mnoz1.add('реле') # добавление элемента
mnoz1
{'датчик', 'реле', 'двигатель', 'микропроцессор', 'линия связи'}
mnoz1.remove('линия связи') # удаление элемента
mnoz1
{'датчик', 'реле', 'двигатель', 'микропроцессор'}

9 Завершение работы.