Сравнить коммиты

..

9 Коммитов
main ... master

Автор SHA1 Сообщение Дата
Пользователь № 6 аудитории Ж-202 24c1a1e50e Индивидуальное задание тема 2
5 дней назад
Пользователь № 6 аудитории Ж-202 920a95b0c2 добавлено контрольное задание
5 дней назад
EfimovaLA e40e07b24a Изменил(а) на 'TEMA2/task.md'
6 дней назад
main-py11 7f7493652d Добавлено общее контрольное задание по теме 2
6 дней назад
main-py11 2cb3ef0762 добавлено общее контрольное задание
6 дней назад
main-py11 966b203ebb исправлен report по теме 2
1 неделю назад
main-py11 6a9a6d8092 добавлен report по теме 2
1 неделю назад
EfimovaLA 6f120c1038 Изменил(а) на 'TEMA1/report/report.md'
1 месяц назад
EfimovaLA 655623404b Тема1/report.md
1 месяц назад

@ -1,7 +1,6 @@
# Программное обеспечение автоматизированных систем: лабораторные работы
[Репозиторий с методическими указаниями и заданиями.](http://uit.mpei.ru/git/main/python)
Обратите внимание на файл с комментариями в репозитории по ссылке.
## Работа с Git
@ -110,7 +109,7 @@
### Оформление решений
Решение всех заданий и тестов оформляется по образцу:
Решение всех заданий оформляется по образцу:
# Общее контрольное задание по теме 2
@ -130,8 +129,5 @@
Для темы 1 вместо «Задания» — «Вопрос», вместо «Решения» — «Ответ».
Для тем 3, 6 и 9 вместо «Индивидуального контрольного задания по теме 3 (6, 9)» —
«Тест по модулю 1 (2, 3)».
Для тем 8 и 9 раздела «Решение» не нужно,
вместо этого решение размещается в отдельных файлах `*.py`.

Двоичные данные
TEMA1/report/figure0.PNG

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 2.4 KiB

Двоичные данные
TEMA1/report/figure1.PNG

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 32 KiB

Двоичные данные
TEMA1/report/figure2.PNG

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 14 KiB

Двоичные данные
TEMA1/report/figure3.PNG

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 5.5 KiB

Двоичные данные
TEMA1/report/figure4.PNG

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 23 KiB

Двоичные данные
TEMA1/report/figure5.PNG

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 28 KiB

Двоичные данные
TEMA1/report/figure6.PNG

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 48 KiB

Двоичные данные
TEMA1/report/figure7.PNG

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 49 KiB

@ -0,0 +1,6 @@
#Программа по Теме 1 Ефимова Людмила Алексеевна
print('Hello')
h=input('Your name=')
import os
os.chdir('C:\\Users\\u207-03\\Desktop\\ПОАС\\python-labs\\TEMA1\\report')

@ -0,0 +1,88 @@
# Отчет по теме 1
Ефимова Людмила, А-03-23
## 1 Изучение среды IDLE
## 1.1 Знакомство с Python 3.4 (command line)
```
>>> print('Hello')
Hello
>>> h=input('Your name=')
Your name=Lyudmila
```
![Скриншот окна программы в командной строке](figure0.PNG)
## 1.2 Изучение графической оболочки IDLE
```
import os
os.chdir('C:\\Users\\u207-03\\Desktop\\ПОАС\\python-labs\\TEMA1\\report')
```
Скриншоты настройки среды.
![Скриншот окна настройки шрифта](figure1.PNG)
![Скриншот окна настройки окна](figure2.PNG)
## 1.3 Создание программы по пунктам 3,4,8:
Создан файл pr0:
```
#Программа по Теме 1 Ефимова Людмила Алексеевна
print('Hello')
h=input('Your name=')
import os
os.chdir('C:\\Users\\u207-03\\Desktop\\ПОАС\\python-labs\\TEMA1\\report')
```
Вывод программы:
```
================== RESTART: C:\Users\u207-03\Desktop\ПОАС\python-labs\TEMA1\report\pr0.py ==================
Hello
Your name=Ludmila
```
## 1.4 Проверка программы prb1:
```
import prb1
Как Вас зовут? Людмила
Привет, Людмила
```
## 1.5 Изучение каталога __pycache__
Открыла каталог и запустила в текстовом редакторе файл pr0.cpython-311.pyc:
![Скриншот окна фрагмента файла pr0.cpython-311.pyc](figure3.PNG)
Данный файл нужен для исполнения кода виртуальной машиной python.
Файл расширения .pyc это скомпилированный файл для изначального кода. В нем содержится кеш выполнения программы
## 1.6 Изучение команды help
В среде пограммирования введены команды help(print) и help(input)
![Скриншот окна фрагмента файла pr0.cpython-311.pyc](figure4.PNG)
Получили вывод - инструкции по работе с командами.
## 1.7 Выполнение функции 15
В редакторе открыла файл prb1 и запустила его.
Получен вывод:
```
============== RESTART: C:\Users\u207-03\Desktop\ПОАС\python-labs\TEMA1\report\prb1.py =============
Как Вас зовут? Людмила
Привет, Людмила
```
Открыт файл tdemo_chaos, изучено его содержимое.
![Скриншот окна с кодом программы](figure5.PNG)
После запуска получен вывод программы:
![Скриншот окна с выводом программы](figure6.PNG)
Запущен пример программы Часы (Clock) из пакета Turtle:
![Скриншот окна с примером часов](figure7.PNG)

@ -3,7 +3,6 @@
# Date: 2009-06-24
# A demonstration of chaos
from turtle import *
N = 80
@ -53,7 +52,6 @@ def main():
for s in range(100):
setworldcoordinates(0.5*s,-0.1, N+1, 1.1)
return "Done!"
if __name__ == "__main__":
main()
mainloop()

@ -0,0 +1,439 @@
# Отчет по теме 2
Ефимова Людмила, А-03-23
## Базовые типы объектов
## 1. Открыла оболочку IDLE и установила рабочий каталог.
В оболочке указала актуальный рабочий каталог. Создала рабочий протокол.
## 2. Изучение простых объектов
Рассмотрим операцию присваивания значения переменным
```py
f1=16; f2=3
f1,f2
(16, 3)
```
Используем команду dir(), чтобы узнать какие объекты существуют в среде на данный момент
```py
dir()
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'f1', 'f2', 'os']
```
Получаем атрибуты объекта f1 с помощью dir, определяем классовую принадлежность объекта f2 с помощью команды type(), удалили объекты f1 иf2 с помощью команды del и проверила их удаление.
```py
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', 'numerator', 'real', 'to_bytes']
type(f2)
<class 'int'>
del f1,f2
f1,f2
Traceback (most recent call last):
File "<pyshell#14>", line 1, in <module>
f1,f2
NameError: name 'f1' is not defined
```
## 3. Изучение правил наименования объектов в Python.
```py
gg1=1.6 #значение в виде вещественного числа
hh1='Строка' #значение в виде символьной строки
73sr=3 #неправильное имя – начинается с цифры - будет диагностика!
SyntaxError: invalid decimal literal
and=7 #недопустимое имя – совпадает с ключевым словом - будет диагностика!
SyntaxError: invalid syntax
```
## 4. Просмотр ключевых слов.
Просмотрели ключевые слова и сохранили их список в переменную lis
```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']
lis =keyword.kwlist
```
## 5. Изучение встроенных идентификаторов
Получила список встроенных идентификаторов с помощью команды dir(builtins)
```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', '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', '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, len, max, min, pow, round, sorted, sum, zip и применила их
```py
abs(-200) # модуль числа
200
len('Hellooo') # длина строки
7
min(0, -9, 100) # поиск минимального числа
-9
max(0, -9, 100) # поиск максимального числа
100
pow(2, 5) # возведение числа в степень
32
round(2.9879, 2) # округление первого числа до количества знаков, переданного во втором аргументе
2.99
sorted([1,6,100,-9,78]) # сортирует числа списка по возрастанию
[-9, 1, 6, 78, 100]
num = [1,2,3,4]
summa = sum(num) # вычисляет сумму элементов списка
summa
10
list(zip([1,2,3],[4,5,6])) # объединяет объекты попарно
[(1, 4), (2, 5), (3, 6)]
```
## 6. Проверка чувствительности регистру
Убедились что объекты чувствительны к регистру
```py
Gg1=45
Gg1, gg1
(45, 1.6)
```
## 7. Изучение базовых типов объектов
Изучили основные простые числовые типы объектов
```py
bb1=True; bb2=False
bb1;bb2
True
False
type(bb1) #функция, показывающая тип (класс) объекта
<class 'bool'>
ii1=-1234567890
ff1=-8.9876e-12 #экспоненциальная форма записи вещественного числа
dv1=0b1101010 #Это – двоичное число.
type(dv1)
<class 'int'>
vsm1=0o52765 #Это – восьмеричное число
shest1=0x7109af6 #Это – шестнадцатеричное число
cc1=2-3j
a=3.67; b=-0.45
cc2=complex(a,b)
cc2
(3.67-0.45j)
```
Работа со строками
```py
ss1='Это - строка символов'
ss1="Это - строка символов"
ss1
'Это - строка символов'
```
Внутри строки можно использовать “экранированные последовательности”
``` py
ss1a="Это - \" строка символов \", \n \t выводимая на двух строках"
print(ss1a)
Это - " строка символов ",
выводимая на двух строках
ss1b= 'Меня зовут: \n <Ефимова Л.А.>'
print(ss1b)
Меня зовут:
<Ефимова Л.А.>
```
Задание многострочных строк через тройные кавычки
```py
mnogo="""Нетрудно заметить , что в результате операции
над числами разных типов получается число,
имеющее более сложный тип из тех, которые участвуют в операции."""
print(mnogo)
Нетрудно заметить , что в результате операции
над числами разных типов получается число,
имеющее более сложный тип из тех, которые участвуют в операции.
```
Обращение к частям строки с помощью индекса символа по порядку.
``` py
ss1[0] #Это – символ «Э»
'Э'
ss1[8] #А это – символ «р»
'р'
ss1[-2] #А это – символ «о» (при знаке «-»(минус) отсчет от конца строки)
'о'
ss1[6:9] #Это часть строки – символы с 6-го индекса по 8-й (9-й не включается!)
'стр'
ss1[13:] #Это часть строки – с 13-го индекса и до конца
'символов'
ss1[:13] #Это часть строки – с начала и до 12-го индекса включительно
'Это - строка '
ss1[5:-8] #Это часть строки – с 5-го индекса и до 8-го от конца
' строка '
ss1[3:17:2] #Часть строки – с 3-го по 16-й индексы с шагом 2
' тоасм'
ss1[17:3:-2]
'омсаот '
ss1[-4:3:-2] # заменили 17 на -4
'омсаот '
ss1[4]='=' # Будет диагностика!
Traceback (most recent call last):
File "<pyshell#12>", line 1, in <module>
ss1[4]='=' # Будет диагностика!
TypeError: 'str' object does not support item assignment
ss1=ss1[:4]+'='+ss1[5:]
print(ss1)
Это = строка символов
```
Проделаем тоже самое со строкой ss1b
```py
ss1b
'Меня зовут: \n <Ефимова Л.А.>'
ss1b[3]
'я'
ss1b[3-2]
'е'
ss1b[-3]
'А'
ss1b[-3:]
'А.>'
ss1b[0:-1]
'Меня зовут: \n <Ефимова Л.А.'
ss1b[3:-3]
'я зовут: \n <Ефимова Л.'
ss1b[::-1]
'>.А.Л авомифЕ< \n :тувоз янеМ'
```
### 7.1. Самостоятельно создала объекты разных типов.
```py
str = '10' + 'aaaaa'
type(str)
<class 'str'>
str
'10aaaaa'
x = 100
type(x)
<class 'int'>
x
100
y = 0.1
type(y)
<class 'float'>
y
0.1
c = 1-1j
c
(1-1j)
type(c)
<class 'complex'>
t = True
type(t)
<class 'bool'>
```
## 8. Изучение сложных типов объектов
### 8.2 Список
Список – упорядоченная по местоположению коллекция объектов произвольных типов, размер которых практически не ограничен.
```py
spis1=[111,'Spisok',5-9j] # список с 3 элементами разных типов
stup=[0,0,1,1,1,1,1,1,1]
spis=[1,2,3,4,
5,6,7,
8,9,10] # ввод на нескольких строках
spis1[-1] # использование индексов
(5-9j)
stup[-8::2]
[0, 1, 1, 1]
spis1[1]='Список' # элементы списка можно изменить
spis1
[111, 'Список', (5-9j)]
len(spis1) # узнать длину списка
3
```
Методы объекта находятся в списке его атрибутов, который выводится с помощью уже известной функции dir()
```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.
dir(spis1)
['__add__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getstate__', '__gt__', '__hash__', '__iadd__', '__imul__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']
```
С помощью методов объектов-списков можно добавлять и удалять элементы:
```py
spis1.append('New item') # добавление нового элемента в конец
spis1
[111, 'Список', (5-9j), 'New item']
spis1+['New item']
[111, 'Список', (5-9j), 'New item', 'New item']
spis1.append(ss1b)
spis1
[111, 'Список', (5-9j), 'New item', 'Меня зовут: \n <Ефимова Л.А.>']
spis1.pop(1) # удаление объекта
'Список'
spis1
[111, (5-9j), 'New item', 'Меня зовут: \n <Ефимова Л.А.>']
spis2=[spis1,[4,5,6,7]] #здесь элементами являются два списка
spis2
[[111, (5-9j), 'New item', 'Меня зовут: \n <Ефимова Л.А.>'], [4, 5, 6, 7]]
spis2[0][1] #обращение к элементу списка spis1
(5-9j)
spis2[0][1]=78 #Убедитесь, что значение элемента заменено на 78
spis2
[[111, 78, 'New item', 'Меня зовут: \n <Ефимова Л.А.>'], [4, 5, 6, 7]]
```
Другие методы объектов-списков:
```py
list = [0, 0, 0, 0, 0]
list.insert(1,4) # добавление 4 на 1 место
list
[0, 4, 0, 0, 0, 0]
list.remove(4) # удаление первого элемента равного 4
list
[0, 0, 0, 0, 0]
list = [1, 2, 3, 4]
list.extend(list[:4]) # продление списка на первые 4 элемента
list
[1, 2, 3, 4, 1, 2, 3, 4]
list.sort() # сортировка списка
list
[1, 1, 2, 2, 3, 3, 4, 4]
list.reverse() # противоположный порядок
list
[4, 4, 3, 3, 2, 2, 1, 1]
list.count(1) # количество вхождений 1 в список
2
list.index(1) # возвращает индекс элемента соответствующего указанному
6
```
### 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, 'Меня зовут: \n <Ефимова Л.А.>')
kort2=kort1[:2]+kort1[3:] # переопределение кортежа с удалением комплексного элемента
kort2
(222, 'Kortezh', 1, 2, 'Меня зовут: \n <Ефимова Л.А.>')
kort1.index(2)
4
kort1.count(222)
1
kort1[2]=90 #Будет получена диагностика о невозможности изменения кортежа
Traceback (most recent call last):
File "<pyshell#121>", line 1, in <module>
kort1[2]=90 #Будет получена диагностика о невозможности изменения кортежа
TypeError: 'tuple' object does not support item assignment
```
### 8.3 Объект-словарь
Содержанием является совокупность пар «ключ (key)»:«значение (value)».
В качестве ключей могут использоваться неизменяемые типы объектов. Значения – объекты любого типа
```py
dic1={'Saratov':145, 'Orel':56, 'Vologda':45}
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]
```
Элементы словаря также могут быть словарями
```py
dic2={1:'mean',2:'standart deviation',3:'correlation'}
dic3={'statistics':dic2,'POAS':['base','elementary','programming']}
dic3['statistics'][2]
'standart deviation'
```
Можно создавать словарь из списка с элементами кортежами и из двух списков
```py
dic4=dict([(1,['A','B','C']),(2,[4,5]),('Q','Prim'),('Stroka',ss1b)])
dic4
{1: ['A', 'B', 'C'], 2: [4, 5], 'Q': 'Prim', 'Stroka': 'Меня зовут: \n <Ефимова Л.А.>'}
dic5=dict(zip(['A','B','C','Stroka'],[16,-3,9,ss1b])) # создание словарей из просто двух списков
dic5
{'A': 16, 'B': -3, 'C': 9, 'Stroka': 'Меня зовут: \n <Ефимова Л.А.>'}
```
Создадим объект-кортеж с 7 элементами и объект-список с 5 элементами. Число ключей должно быть равно числу значений, в данном случае словарь создастся с количеством элементов равным наименьшей из длин списка ключей или значений.
```py
cort=(1,3,5,7,8,10,12)
spisok = ['A', 'B', 'C', 'D', 'E']
dict1 = dict(zip(cort, spisok))
dict1
{1: 'A', 3: 'B', 5: 'C', 7: 'D', 8: 'E'}
```
Словарь с описанием студентов
```py
AVTI = {"Курс I" : [22, 23, 17, 24, 30, 29, 28, 25, 23, 0, 4, 31, 30, 33, 18, 12, 27],
"Курс II" : [18, 16, 12, 15, 29, 18, 21, 23, 13, 0, 4, 20, 31, 26, 16],
"Курс III" : [17, 12, 0, 6, 17, 15, 19, 19, 0, 0, 5, 17, 22, 18, 12],
"Курс IV" : [27, 16, 0, 13, 17, 15, 19, 20, 0, 0, 2, 15, 18, 16, 17]}
AVTI["Курс III"][5]
15
```
### 8.4. Объекты-множества
Это неупорядоченная совокупность неповторяющихся элементов. Могут быть разных типов, но только неизменяемых
```py
mnoz1={'двигатель','датчик','линия связи','датчик','микропроцессор','двигатель'}
mnoz1
{'двигатель', 'линия связи', 'микропроцессор', 'датчик'}
len(mnoz1)
4
'датчик' in mnoz1 # проверка наличия элемента
True
mnoz1.add('реле') # добавление элемента
mnoz1.remove('линия связи') # удаление элемента
mnoz1
{'микропроцессор', 'двигатель', 'реле', 'датчик'}
```
Придумала свой объект множество
```py
mnoz2 = {123, 'text', (1,2,3)}
mnoz2.add('ffff')
len(mnoz2)
4
mnoz2
{123, 'text', (1, 2, 3), 'ffff'}
mnoz2.remove('text')
mnoz2
{123, (1, 2, 3), 'ffff'}
```
## 9. Завершила работу со средой.
Сохранила файлы отчета и завершила сеанс работы со средой.

@ -0,0 +1,51 @@
# Общее контрольное задание по теме 2
Ефимова Людмила Алексеевна, А-03-23
## Задание
Реализовать, записать в текстовый файл и проанализировать результаты последовательности инструкций, выполняющих следующие действия: • Создать переменную с именем familia и со значением - символьной строкой – своей фамилией в латинской транскрипции.
• Создать переменную со значением, совпадающим с первой буквой из familia.
• Создать переменную с именем sp_kw со значением – списком всей ключевых слов языка Python.
• Удалите из списка sp_kw значение 'nonlocal'. Выводом списка в командном окне IDLE убедитесь, что это значение удалено из списка.
• Создайте кортеж kort_nam с именами: вашим и еще 3-х студентов из вашей группы. Напишите инструкцию, позволяющую убедиться, что тип переменной – это tuple.
• Напишите инструкцию, добавляющую в kort_nam имена еще двух студентов.
• Напишите инструкцию, позволяющую определить, сколько раз в кортеже присутствуют студенты с именем «Дима».
• Создайте словарь dict_bas, в котором ключами являются русские названия типов переменных, использованных в предыдущих операторах, а значениями – ранее созданные переменные, соответствующие этим типам.
## Решение
```py
familia = "Efimova"
first = familia[0] # значение первая буква из familia
first
'E'
import keyword
sp_kw = keyword.kwlist # значение список всех ключевых слов языка
sp_kw
['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_kw.remove("nonlocal") # удаляем элемент nonlocal
sp_kw
['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 = ("Lyudmila", "Maria", "Danil", "Dima")
type(kort_nam)
<class 'tuple'>
kort_nam += ("Artem", "Ilya")
kort_nam
('Lyudmila', 'Maria', 'Danil', 'Dima', 'Artem', 'Ilya')
kort_nam.count("Dima")
1
dict_bas = {'строка' : familia, 'список' : sp_kw, 'кортеж' : kort_nam} # создаем словарь
dict_bas
{'строка': 'Efimova', 'список': ['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'], 'кортеж': ('Lyudmila', 'Maria', 'Danil', 'Dima', 'Artem', 'Ilya')}
```

@ -0,0 +1,19 @@
# Индивидуальное контрольное задание
Ефимова Людмила, А-03-23
## Задание 17
Создайте два списка: один – с фамилиями 3-х студентов вашей группы, другой – с 5 числами: 11,12,13,14,15.
Напишите инструкцию создания словаря, в котором фамилии студентов были бы ключами, а числа – значениями.
Отобразите получившийся словарь.
Отобразите его ключи с упорядочением по фамилиям студентов.
## Решение
```py
familii = ['Ефимова', 'Девятова','Беженарь']
num = [11, 12, 13, 14, 15]
dic = dict(zip(familii, num))
dic
{'Ефимова': 11, 'Девятова': 12, 'Беженарь': 13}
sorted(dic.keys())
['Беженарь', 'Девятова', 'Ефимова']
```

@ -0,0 +1,19 @@
# Индивидуальное контрольное задание
Ефимова Людмила, А-03-23
## Задание 17
Создайте два списка: один – с фамилиями 3-х студентов вашей группы, другой – с 5 числами: 11,12,13,14,15.
Напишите инструкцию создания словаря, в котором фамилии студентов были бы ключами, а числа – значениями.
Отобразите получившийся словарь.
Отобразите его ключи с упорядочением по фамилиям студентов.
## Решение
```py
familii = ['Ефимова', 'Девятова','Беженарь']
num = [11, 12, 13, 14, 15]
dic = dict(zip(familii, num))
dic
{'Ефимова': 11, 'Девятова': 12, 'Беженарь': 13}
sorted(dic.keys())
['Беженарь', 'Девятова', 'Ефимова']
```
Загрузка…
Отмена
Сохранить