форкнуто от main/python-labs
Родитель
fa791ed67e
Сommit
12e60c424f
@ -0,0 +1 @@
|
||||
запись строки в файл
|
||||
Двоичный файл не отображается.
@ -0,0 +1,491 @@
|
||||
# Отчет по теме 6 <Лазарев Данил Вячеславович>
|
||||
#А-01-23
|
||||
|
||||
## 1.Запуск интерактивной оболочки IDLE.
|
||||
|
||||
```
|
||||
import os
|
||||
os.chdir("C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6")
|
||||
```
|
||||
|
||||
## 2. Вывод данных на экран дисплея
|
||||
|
||||
##2.1. Вывод данных в командной строке.
|
||||
|
||||
Реализация эхо-вывода в терминал.
|
||||
```
|
||||
stroka='Автоматизированная система управления'
|
||||
stroka
|
||||
'Автоматизированная система управления'
|
||||
```
|
||||
|
||||
## 2.2 Вывод с использованием функции print
|
||||
Данная функция применима и в командной строке, и в функциях.
|
||||
```
|
||||
fff = 234.5; gg = 'Значение температуры = '
|
||||
print(gg, fff)
|
||||
Значение температуры = 234.5
|
||||
```
|
||||
|
||||
По умолчанию выводимые объекты разделяются одним пробелом. Если нужен другой разделитель его можно указать в отдельном аргументе sep
|
||||
|
||||
```
|
||||
print(gg, fff, sep='/')
|
||||
Значение температуры = /234.5
|
||||
```
|
||||
|
||||
По умолчанию после того, как функция print() сделала вывод, происходит перенос каретки на
|
||||
следующую строку. Это тоже можно изменить. Параметр end по умолчанию имеет значение "\n",
|
||||
его можно изменить на другое.
|
||||
|
||||
```
|
||||
print(gg, fff,sep='/',end='***'); print('____')
|
||||
Значение температуры = /234.5***____
|
||||
|
||||
print()
|
||||
|
||||
>>
|
||||
```
|
||||
|
||||
Если текст большой,то можно расположить его в несколько строк:
|
||||
|
||||
```
|
||||
print(""" Здесь может выводиться
|
||||
большой текст,
|
||||
занимающий несколько строк""")
|
||||
>>Здесь может выводиться
|
||||
>>большой текст,
|
||||
>>занимающий несколько строк
|
||||
|
||||
print("Здесь может выводиться",
|
||||
"большой текст,",
|
||||
"занимающий несколько строк")
|
||||
Здесь может выводиться большой текст, занимающий несколько строк
|
||||
|
||||
```
|
||||
|
||||
## 2.3. Вывод с использованием write объекта stdout (поток стандартного вывода) модуля sys.
|
||||
|
||||
```
|
||||
help(sys.stdout.write)
|
||||
Help on method write in module idlelib.run:
|
||||
|
||||
write(s) method of idlelib.run.StdOutputFile instance
|
||||
Write string to stream.
|
||||
Returns the number of characters written (which is always equal to
|
||||
the length of the string).
|
||||
|
||||
import sys
|
||||
sys.stdout.write("Функция write")
|
||||
>> Функция write13
|
||||
|
||||
>> sys.stdout.write("Функция write\n") #Добавлен переход н новую строку
|
||||
Функция write
|
||||
14
|
||||
```
|
||||
|
||||
Заметим, что функция выводит текст, но также возвращает число. Это число отображает количество
|
||||
введенных символов.
|
||||
|
||||
## 3. Ввод данных с клавиатуры.
|
||||
Для ввода используйте уже знакомую функцию 'input'.
|
||||
```
|
||||
psw = input('Введите пароль:')
|
||||
Введите пароль:12345
|
||||
psw
|
||||
>>'12345'
|
||||
type(psw)
|
||||
>> <class 'str'>
|
||||
```
|
||||
|
||||
Пример 1
|
||||
```
|
||||
|
||||
while True:
|
||||
znach=float(input('Задайте коэф.усиления = '))
|
||||
if znach < 17.5 or znach > 23.8:
|
||||
print('Ошибка!')
|
||||
else:
|
||||
break
|
||||
|
||||
|
||||
Задайте коэф.усиления = 18
|
||||
znach
|
||||
>>18.0
|
||||
|
||||
Задайте коэф.усиления = 17
|
||||
>> Ошибка!
|
||||
```
|
||||
|
||||
Пример 2
|
||||
```
|
||||
import math
|
||||
print(eval(input('введите выражение для расчета = ')))
|
||||
введите выражение для расчета = math.log10(23 / (1 + math.exp(-3.24)))
|
||||
>> 1.34504378689765
|
||||
|
||||
```
|
||||
|
||||
## 4. Ввод-вывод при работе с файлами.
|
||||
|
||||
### 4.1. Функции для работы с путём к файлу.
|
||||
|
||||
```
|
||||
import os
|
||||
os.getcwd()
|
||||
>> 'C:\\Users\\Dannyan\\AppData\\Local\\Programs\\Python\\Python313'
|
||||
Lazarev = os.getcwd()
|
||||
print(Lazarev)
|
||||
C:\Users\Dannyan\AppData\Local\Programs\Python\Python313
|
||||
Lazarev
|
||||
>> 'C:\\Users\\Dannyan\\AppData\\Local\\Programs\\Python\\Python313'
|
||||
os.chdir('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6')
|
||||
os.getcwd()
|
||||
>> 'C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6'
|
||||
|
||||
```
|
||||
Изучение функции mkdir
|
||||
```
|
||||
os.mkdir('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\new')
|
||||
os.listdir('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6')
|
||||
>> ['.gitkeep', 'new', 'protocol6.py']
|
||||
```
|
||||
Удаление каталога функция rmdir
|
||||
```
|
||||
os.rmdir("new")
|
||||
>> Traceback (most recent call last):
|
||||
File "<pyshell#25>", line 1, in <module>
|
||||
os.rmdir("new")
|
||||
PermissionError: [WinError 5] Отказано в доступе: 'new'
|
||||
???
|
||||
```
|
||||
Показать список всех файлов и папок, вложенных в текущую(listdir)
|
||||
```
|
||||
os.listdir('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6')
|
||||
>> ['.gitkeep', 'protocol6.py']
|
||||
```
|
||||
Проверка существования каталога(isdir)
|
||||
```
|
||||
help(os.path.isdir)
|
||||
Help on function isdir in module genericpath:
|
||||
|
||||
isdir(s)
|
||||
Return true if the pathname refers to an existing directory.
|
||||
|
||||
os.path.isdir('new')
|
||||
>> True
|
||||
os.path.isdir('frog')
|
||||
>> False
|
||||
```
|
||||
|
||||
С помощью функции os.path.abspath можно получить символьную строку, содержащую имя файла вместе с полным путем доступа к нему:
|
||||
```
|
||||
fil=os.path.abspath("new")
|
||||
fil
|
||||
>> 'C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\new'
|
||||
```
|
||||
Отделение из пути только каталога/только имени файла
|
||||
```
|
||||
drkt=os.path.dirname(fil)
|
||||
drkt
|
||||
>> 'C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6'
|
||||
|
||||
bs = os.path.basename(drkt)
|
||||
bs
|
||||
>> 'TEMA6'
|
||||
```
|
||||
|
||||
Разделение на кортеж из пути и из имени файла
|
||||
```
|
||||
res = os.path.split('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\new')
|
||||
res
|
||||
('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6', 'new')
|
||||
```
|
||||
|
||||
Проверка существования любого объекта
|
||||
```
|
||||
os.path.exists('C:\Games')
|
||||
True
|
||||
os.path.exists('C:\load')
|
||||
False
|
||||
```
|
||||
Проверка существования файла
|
||||
```
|
||||
os.path.isfile(fil)
|
||||
False
|
||||
os.path.isfile('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\new')
|
||||
False
|
||||
```
|
||||
### 4.2 Общая схема работы с файлом
|
||||
|
||||
Для обмена данными с файлом необходимо выполнить следующие операции:
|
||||
|
||||
• Открытие файла с указанием его имени и цели (чтение, запись, добавление данных);
|
||||
|
||||
• Выполнение одной или нескольких операций обмена данными с файлом;
|
||||
|
||||
• Закрытие файла.
|
||||
|
||||
### 4.3 Открытие файла для записи или чтения
|
||||
|
||||
```
|
||||
fp=open(file=drkt+'\\zapis1.txt',mode='w')
|
||||
fp
|
||||
>> <_io.TextIOWrapper name='C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\zapis1.txt' mode='w' encoding='cp1251'>
|
||||
type(fp)
|
||||
|
||||
>> <class '_io.TextIOWrapper'>
|
||||
dir(fp)
|
||||
|
||||
>> ['_CHUNK_SIZE', '__class__', '__del__', '__delattr__', '__dict__', '__dir__', '__doc__', '__enter__', '__eq__', '__exit__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__next__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '_checkClosed', '_checkReadable', '_checkSeekable', '_checkWritable', '_finalizing', 'buffer', 'close', 'closed', 'detach', 'encoding', 'errors', 'fileno', 'flush', 'isatty', 'line_buffering', 'mode', 'name', 'newlines', 'read', 'readable', 'readline', 'readlines', 'reconfigure', 'seek', 'seekable', 'tell', 'truncate', 'writable', 'write', 'write_through', 'writelines']
|
||||
|
||||
```
|
||||
Пример открытия бинарного файла
|
||||
```
|
||||
fp1=open(drkt+'\\zapis2.bin',mode='wb+')
|
||||
fp1
|
||||
>> <_io.BufferedRandom name='C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\zapis2.bin'>
|
||||
```
|
||||
|
||||
### 4.4. Закрытие файла.
|
||||
|
||||
Когда файл успешно открывается / создается и открывается, ему задается целочисленный
|
||||
номер, называемый файловым дескриптором. Он создается только на один сеанс работы и указывает,
|
||||
с каким именно файлом нужно работать.
|
||||
|
||||
После того, как программа отработала, надо очистить ресурсы, связанные с файлом (область
|
||||
в оперативной памяти, в буфере при буферизации), и удалить дескриптор. Если не закрыть
|
||||
файл, это может его повредить, данные могут быть утеряны или система может быть перегружена,
|
||||
т.к. исчерпается ресурс оперативной памяти. Для закрытия есть метод close().
|
||||
|
||||
```
|
||||
fp.close()
|
||||
fp.closed
|
||||
>> True
|
||||
os.listdir('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6')
|
||||
|
||||
>> ['.gitkeep', 'new', 'protocol6.py', 'zapis1.txt', 'zapis2.bin']
|
||||
```
|
||||
|
||||
### 4.5. Запись информации в файл.
|
||||
|
||||
```
|
||||
sps=list(range(1,13))
|
||||
fp2=open('zapis3.txt','w')
|
||||
fp2.write(str(sps[:4])+'\n')
|
||||
>> 13
|
||||
fp2.write(str(sps[4:8])+'\n')
|
||||
>> 13
|
||||
fp2.write(str(sps[8:])+'\n')
|
||||
>> 16
|
||||
fp2.close()
|
||||
```
|
||||
|
||||
Посмотрим, как выглядит файл, в текстовом редакторе:
|
||||
|
||||

|
||||
|
||||
В файл записались преобразованные в строки срезы списка. Второй и последущие вызовы write()
|
||||
в рамках одного сеанса не стирают содержимое файла.
|
||||
|
||||
```
|
||||
sps3=[['Иванов И.',1],['Петров П.',2],['Сидоров С.',3]]
|
||||
|
||||
fp3=open('zapis4.txt','w')
|
||||
|
||||
for i in range(len(sps3)):
|
||||
stroka4=sps3[i][0]+' '+str(sps3[i][1])
|
||||
fp3.write(stroka4)
|
||||
|
||||
>> 11
|
||||
>> 11
|
||||
>> 12
|
||||
fp3.close()
|
||||
```
|
||||
|
||||
Файл в текстовом редакторе выглядит так:
|
||||
|
||||

|
||||
|
||||
Видно, что строки склеились там, где не надо. Попробуем иначе.
|
||||
|
||||
```
|
||||
for r in sps3:
|
||||
gh.write(r[0]+' '+str(r[1])+'\n')
|
||||
|
||||
>> 12
|
||||
>> 12
|
||||
>> 13
|
||||
gh.close()
|
||||
```
|
||||
|
||||
Получим новый вид данных в файле:
|
||||

|
||||
|
||||
### 4.6. Чтение из файла
|
||||
|
||||
```
|
||||
sps1=[]
|
||||
|
||||
fp=open('zapis3.txt')
|
||||
|
||||
for stroka in fp:
|
||||
stroka=stroka.rstrip('\n')
|
||||
stroka=stroka.replace('[','')
|
||||
stroka=stroka.replace(']','')
|
||||
sps1=sps1+stroka.split(',')
|
||||
|
||||
fp.close()
|
||||
|
||||
sps1
|
||||
|
||||
>> ['1', ' 2', ' 3', ' 4', '5', ' 6', ' 7', ' 8', '9', ' 10', ' 11', ' 12']
|
||||
```
|
||||
|
||||
Метод .rstrip() убирает символы с конца строки. Если не задавать аргументов,
|
||||
он удалит любые пробелы (пробел, табуляция, символы новой строки и т.п.) с конца строки.
|
||||
|
||||
Метод .replace() заменяет первый агрумент на второй. С помощью него мы убираем скобки.
|
||||
|
||||
```
|
||||
fp = open('zapis3.txt')
|
||||
|
||||
for stroka in fp:
|
||||
stroka = stroka.rstrip('\n')
|
||||
stroka = stroka.replace('[', '')
|
||||
stroka = stroka.replace(']', '')
|
||||
K = stroka.split(',')
|
||||
for i in K:
|
||||
chislo = int(i)
|
||||
sps1.append(chislo)
|
||||
|
||||
fp.close()
|
||||
|
||||
sps1
|
||||
|
||||
>> [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
|
||||
```
|
||||
|
||||
### Пункт 4.7. Чтение информации из файла с помощью метода read.
|
||||
|
||||
Этой функции передается количество символов или, если открыт бинарный файл, - количество
|
||||
байт, которое должно быть прочитано, соответственно, из текстового или бинарного файла,
|
||||
начиная с текущего положения маркера.
|
||||
|
||||
```
|
||||
fp=open('zapis3.txt')
|
||||
stroka1=fp.read(12)
|
||||
stroka2=fp.read()
|
||||
fp.close()
|
||||
|
||||
stroka1
|
||||
>> '[1, 2, 3, 4]'
|
||||
stroka2
|
||||
>> '\n[5, 6, 7, 8]\n[9, 10, 11, 12]\n'
|
||||
```
|
||||
|
||||
### 4.8. Чтение информации с помощью readline и readlines.
|
||||
|
||||
Метод readline() считывает одну строку из файла за один вызов. Он читает символы до тех пор,
|
||||
пока не встретит символ новой строки или конец файла.
|
||||
Если файл содержит только одну строку или указатель чтения находится в конце файла, то при
|
||||
вызове readline() будет возвращена пустая строка.
|
||||
|
||||
```
|
||||
fp = open('zapis3.txt')
|
||||
a = fp.readline()
|
||||
b = fp.readline()
|
||||
fp.close()
|
||||
|
||||
a
|
||||
>> '[1, 2, 3, 4]\n'
|
||||
b
|
||||
>> '[5, 6, 7, 8]\n'
|
||||
|
||||
fp=open('zapis3.txt')
|
||||
s = fp.readlines()
|
||||
s
|
||||
>> ['[1, 2, 3, 4]\n', '[5, 6, 7, 8]\n', '[9, 10, 11, 12]\n']
|
||||
```
|
||||
|
||||
### 4.9. Ввод-вывод объектов с использованием функций из модуля pickle.
|
||||
|
||||
Этот модуль предназначен для перевода объектов в бинарную форму.
|
||||
|
||||
```
|
||||
import pickle
|
||||
mnoz1={'pen','book','pen','iPhone','table','book'}
|
||||
fp=open('zapis6.mnz','wb')
|
||||
pickle.dump(mnoz1,fp)
|
||||
fp.close()
|
||||
```
|
||||
|
||||
Откроем получившийся файл в текстовом редакторе:
|
||||
|
||||

|
||||
Так происходит, потому что байты не предназначены для текстового представления.
|
||||
Они могут содержать символы, которые не могут быть интерпретированы в рамках
|
||||
текстовой кодировки.
|
||||
|
||||
```
|
||||
fp=open('zapis6.mnz','rb')
|
||||
mnoz2=pickle.load(fp)
|
||||
fp.close()
|
||||
mnoz2
|
||||
>> {'pen', 'iPhone', 'table', 'book'}
|
||||
mnoz1 == mnoz2 # автоматическое объединение повторяющихся объектов
|
||||
>> True
|
||||
|
||||
fp=open('zapis7.2ob','wb')
|
||||
pickle.dump(mnoz1,fp)
|
||||
pickle.dump(sps3,fp)
|
||||
fp.close()
|
||||
fp=open('zapis7.2ob','rb')
|
||||
obj1=pickle.load(fp)
|
||||
obj2=pickle.load(fp)
|
||||
fp.close()
|
||||
obj1
|
||||
>> {'pen', 'iPhone', 'table', 'book'}
|
||||
obj2
|
||||
>> [['Иванов И.', 1], ['Петров П.', 2], ['Сидоров С.', 3]]
|
||||
mnoz1 == obj1
|
||||
>> True
|
||||
sps3 == obj2
|
||||
>> True
|
||||
```
|
||||
|
||||
### 5. Перенаправление потоков ввода и вывода данных.
|
||||
|
||||
Поток в python позволяет регулировать источники
|
||||
ввода информации и то, куда её выводить. Всего их по умолчанию три:
|
||||
|
||||
sys.stdin — поток ввода
|
||||
sys.stdout — поток вывода
|
||||
sys.stderr — поток ошибок
|
||||
|
||||
```
|
||||
import sys
|
||||
vr_out=sys.stdout
|
||||
fc=open('Stroka.txt','w') #Откроем файл вывода
|
||||
sys.stdout=fc #Перенацеливаем стандартный поток вывода на файл
|
||||
print('запись строки в файл') #Вывод теперь будет не на экран, а в файл
|
||||
sys.stdout=vr_out #Восстановление текущего потока
|
||||
print('запись строки на экран') #Убеждаемся, что вывод на экран восстановился
|
||||
>> запись строки на экран
|
||||
fc.close()
|
||||
tmp_in = sys.stdin #Запоминаем текущий поток ввода
|
||||
fd = open("Stroka.txt", "r") #Открываем файл для ввода (чтения)
|
||||
sys.stdin = fd #Перенацеливаем ввод на файл вместо клавиатуры
|
||||
sys.stdin
|
||||
>> <_io.TextIOWrapper name='Stroka.txt' mode='r' encoding='cp1251'>
|
||||
while True:
|
||||
try:
|
||||
line = input () #Считываем из файла строку
|
||||
print(line) # Отображаем считанное
|
||||
except EOFError:
|
||||
break
|
||||
|
||||
>> запись строки в файл
|
||||
fd.close()
|
||||
sys.stdin=tmp_in #Не забыть вернуть стандартное назначение для потока ввода
|
||||
```
|
||||
@ -0,0 +1,481 @@
|
||||
# Отчет по теме 6 <Лазарев Данил Вячеславович>
|
||||
#А-01-23
|
||||
|
||||
## 1.Запуск интерактивной оболочки IDLE.
|
||||
|
||||
```
|
||||
import os
|
||||
os.chdir("C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6")
|
||||
```
|
||||
|
||||
## 2. Вывод данных на экран дисплея
|
||||
|
||||
##2.1. Вывод данных в командной строке.
|
||||
|
||||
Реализация эхо-вывода в терминал.
|
||||
```
|
||||
stroka='Автоматизированная система управления'
|
||||
stroka
|
||||
'Автоматизированная система управления'
|
||||
```
|
||||
|
||||
## 2.2 Вывод с использованием функции print
|
||||
Данная функция применима и в командной строке, и в функциях.
|
||||
``
|
||||
fff = 234.5; gg = 'Значение температуры = '
|
||||
print(gg, fff)
|
||||
Значение температуры = 234.5
|
||||
```
|
||||
|
||||
По умолчанию выводимые объекты разделяются одним пробелом. Если нужен другой разделитель его можно указать в отдельном аргументе sep
|
||||
|
||||
```
|
||||
print(gg, fff, sep='/')
|
||||
Значение температуры = /234.5
|
||||
```
|
||||
|
||||
По умолчанию после того, как функция print() сделала вывод, происходит перенос каретки на
|
||||
следующую строку. Это тоже можно изменить. Параметр end по умолчанию имеет значение "\n",
|
||||
его можно изменить на другое.
|
||||
|
||||
```
|
||||
print(gg, fff,sep='/',end='***'); print('____')
|
||||
Значение температуры = /234.5***____
|
||||
|
||||
print()
|
||||
|
||||
>>
|
||||
```
|
||||
|
||||
Если текст большой,то можно расположить его в несколько строк:
|
||||
|
||||
```
|
||||
print(""" Здесь может выводиться
|
||||
большой текст,
|
||||
занимающий несколько строк""")
|
||||
>>Здесь может выводиться
|
||||
>>большой текст,
|
||||
>>занимающий несколько строк
|
||||
|
||||
print("Здесь может выводиться",
|
||||
"большой текст,",
|
||||
"занимающий несколько строк")
|
||||
Здесь может выводиться большой текст, занимающий несколько строк
|
||||
|
||||
```
|
||||
|
||||
## 2.3. Вывод с использованием write объекта stdout (поток стандартного вывода) модуля sys.
|
||||
|
||||
```
|
||||
help(sys.stdout.write)
|
||||
Help on method write in module idlelib.run:
|
||||
|
||||
write(s) method of idlelib.run.StdOutputFile instance
|
||||
Write string to stream.
|
||||
Returns the number of characters written (which is always equal to
|
||||
the length of the string).
|
||||
|
||||
import sys
|
||||
sys.stdout.write("Функция write")
|
||||
>>Функция write13
|
||||
|
||||
>>sys.stdout.write("Функция write\n") #Добавлен переход н новую строку
|
||||
Функция write
|
||||
14
|
||||
```
|
||||
|
||||
Заметим, что функция выводит текст, но также возвращает число. Это число отображает количество
|
||||
введенных символов.
|
||||
|
||||
## 3. Ввод данных с клавиатуры.
|
||||
Для ввода используйте уже знакомую функцию 'input'.
|
||||
```
|
||||
psw = input('Введите пароль:')
|
||||
Введите пароль:12345
|
||||
psw
|
||||
>>'12345'
|
||||
type(psw)
|
||||
>> <class 'str'>
|
||||
```
|
||||
|
||||
|
||||
```
|
||||
# Пример 1
|
||||
while True:
|
||||
znach=float(input('Задайте коэф.усиления = '))
|
||||
if znach < 17.5 or znach > 23.8:
|
||||
print('Ошибка!')
|
||||
else:
|
||||
break
|
||||
|
||||
|
||||
Задайте коэф.усиления = 18
|
||||
znach
|
||||
>>18.0
|
||||
|
||||
Задайте коэф.усиления = 17
|
||||
>> Ошибка!
|
||||
|
||||
#Пример 2
|
||||
import math
|
||||
print(eval(input('введите выражение для расчета = ')))
|
||||
введите выражение для расчета = math.log10(23 / (1 + math.exp(-3.24)))
|
||||
>>1.34504378689765
|
||||
|
||||
```
|
||||
|
||||
## 4. Ввод-вывод при работе с файлами.
|
||||
|
||||
## 4.1. Функции для работы с путём к файлу.
|
||||
|
||||
```
|
||||
import os
|
||||
os.getcwd()
|
||||
>> 'C:\\Users\\Dannyan\\AppData\\Local\\Programs\\Python\\Python313'
|
||||
Lazarev = os.getcwd()
|
||||
print(Lazarev)
|
||||
C:\Users\Dannyan\AppData\Local\Programs\Python\Python313
|
||||
Lazarev
|
||||
>> 'C:\\Users\\Dannyan\\AppData\\Local\\Programs\\Python\\Python313'
|
||||
os.chdir('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6')
|
||||
os.getcwd()
|
||||
>> 'C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6'
|
||||
|
||||
|
||||
#Изучение функции mkdir
|
||||
os.mkdir('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\new')
|
||||
os.listdir('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6')
|
||||
>> ['.gitkeep', 'new', 'protocol6.py']
|
||||
|
||||
#Удаление каталога
|
||||
|
||||
os.rmdir("new")
|
||||
>> Traceback (most recent call last):
|
||||
File "<pyshell#25>", line 1, in <module>
|
||||
os.rmdir("new")
|
||||
PermissionError: [WinError 5] Отказано в доступе: 'new'
|
||||
???
|
||||
|
||||
#Показать список всех файлов и папок, вложенных в текущую
|
||||
|
||||
os.listdir('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6')
|
||||
>> ['.gitkeep', 'protocol6.py']
|
||||
|
||||
#Проверка существования каталога
|
||||
help(os.path.isdir)
|
||||
Help on function isdir in module genericpath:
|
||||
|
||||
isdir(s)
|
||||
Return true if the pathname refers to an existing directory.
|
||||
|
||||
os.path.isdir('new')
|
||||
>> True
|
||||
os.path.isdir('frog')
|
||||
>> False
|
||||
|
||||
# С помощью функции os.path.abspath можно получить символьную строку, содержащую имя файла вместе с полным путем доступа к нему:
|
||||
fil=os.path.abspath("new")
|
||||
fil
|
||||
>> 'C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\new'
|
||||
|
||||
#Отделение из абсолютного пути только каталога/только имени файла
|
||||
drkt=os.path.dirname(fil)
|
||||
drkt
|
||||
>> 'C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6'
|
||||
|
||||
bs = os.path.basename(drkt)
|
||||
bs
|
||||
>> 'TEMA6'
|
||||
|
||||
|
||||
#Разделение на кортеж из пути и из имени файла
|
||||
res = os.path.split('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\new')
|
||||
res
|
||||
('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6', 'new')
|
||||
|
||||
|
||||
#Проверка существования любого объекта
|
||||
os.path.exists('C:\Games')
|
||||
True
|
||||
os.path.exists('C:\load')
|
||||
False
|
||||
|
||||
#Проверка существования файла
|
||||
os.path.isfile(fil)
|
||||
False
|
||||
os.path.isfile('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\new')
|
||||
False
|
||||
|
||||
## 4.2 Общая схема работы с файлом
|
||||
|
||||
Для обмена данными с файлом необходимо выполнить следующие операции:
|
||||
|
||||
• Открытие файла с указанием его имени и цели (чтение, запись, добавление данных);
|
||||
|
||||
• Выполнение одной или нескольких операций обмена данными с файлом;
|
||||
|
||||
• Закрытие файла.
|
||||
|
||||
## 4.3 Открытие файла для записи или чтения
|
||||
|
||||
```
|
||||
fp=open(file=drkt+'\\zapis1.txt',mode='w')
|
||||
fp
|
||||
>> <_io.TextIOWrapper name='C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\zapis1.txt' mode='w' encoding='cp1251'>
|
||||
type(fp)
|
||||
|
||||
>> <class '_io.TextIOWrapper'>
|
||||
dir(fp)
|
||||
|
||||
>> ['_CHUNK_SIZE', '__class__', '__del__', '__delattr__', '__dict__', '__dir__', '__doc__', '__enter__', '__eq__', '__exit__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__next__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '_checkClosed', '_checkReadable', '_checkSeekable', '_checkWritable', '_finalizing', 'buffer', 'close', 'closed', 'detach', 'encoding', 'errors', 'fileno', 'flush', 'isatty', 'line_buffering', 'mode', 'name', 'newlines', 'read', 'readable', 'readline', 'readlines', 'reconfigure', 'seek', 'seekable', 'tell', 'truncate', 'writable', 'write', 'write_through', 'writelines']
|
||||
|
||||
```
|
||||
Пример открытия бинарного файла
|
||||
```
|
||||
fp1=open(drkt+'\\zapis2.bin',mode='wb+')
|
||||
fp1
|
||||
>> <_io.BufferedRandom name='C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\zapis2.bin'>
|
||||
```
|
||||
|
||||
## 4.4. Закрытие файла.
|
||||
|
||||
Когда файл успешно открывается / создается и открывается, ему задается целочисленный
|
||||
номер, называемый файловым дескриптором. Он создается только на один сеанс работы и указывает,
|
||||
с каким именно файлом нужно работать.
|
||||
|
||||
После того, как программа отработала, надо очистить ресурсы, связанные с файлом (область
|
||||
в оперативной памяти, в буфере при буферизации), и удалить дескриптор. Если не закрыть
|
||||
файл, это может его повредить, данные могут быть утеряны или система может быть перегружена,
|
||||
т.к. исчерпается ресурс оперативной памяти. Для закрытия есть метод close().
|
||||
|
||||
```
|
||||
fp.close()
|
||||
fp.closed
|
||||
>> True
|
||||
os.listdir('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6')
|
||||
|
||||
>> ['.gitkeep', 'new', 'protocol6.py', 'zapis1.txt', 'zapis2.bin']
|
||||
```
|
||||
|
||||
## 4.5. Запись информации в файл.
|
||||
|
||||
```
|
||||
sps=list(range(1,13))
|
||||
fp2=open('zapis3.txt','w')
|
||||
fp2.write(str(sps[:4])+'\n')
|
||||
>> 13
|
||||
fp2.write(str(sps[4:8])+'\n')
|
||||
>> 13
|
||||
fp2.write(str(sps[8:])+'\n')
|
||||
>> 16
|
||||
fp2.close()
|
||||
```
|
||||
|
||||
Посмотрим, как выглядит файл, в текстовом редакторе:
|
||||
|
||||
![]ris1.png
|
||||
|
||||
В файл записались преобразованные в строки срезы списка. Второй и последущие вызовы write()
|
||||
в рамках одного сеанса не стирают содержимое файла.
|
||||
|
||||
```
|
||||
sps3=[['Иванов И.',1],['Петров П.',2],['Сидоров С.',3]]
|
||||
|
||||
fp3=open('zapis4.txt','w')
|
||||
|
||||
for i in range(len(sps3)):
|
||||
stroka4=sps3[i][0]+' '+str(sps3[i][1])
|
||||
fp3.write(stroka4)
|
||||
|
||||
>> 11
|
||||
>> 11
|
||||
>> 12
|
||||
fp3.close()
|
||||
```
|
||||
|
||||
Файл в текстовом редакторе выглядит так:
|
||||
|
||||
![]ris2.png
|
||||
|
||||
Видно, что строки склеились там, где не надо. Попробуем по-другому.
|
||||
|
||||
```
|
||||
for r in sps3:
|
||||
gh.write(r[0]+' '+str(r[1])+'\n')
|
||||
|
||||
>> 12
|
||||
>> 12
|
||||
>> 13
|
||||
gh.close()
|
||||
```
|
||||
|
||||
Получим новый вид данных в файле:
|
||||
![]ris3.png
|
||||
|
||||
## 4.6. Чтение из файла
|
||||
|
||||
```
|
||||
sps1=[]
|
||||
|
||||
fp=open('zapis3.txt')
|
||||
|
||||
for stroka in fp:
|
||||
stroka=stroka.rstrip('\n')
|
||||
stroka=stroka.replace('[','')
|
||||
stroka=stroka.replace(']','')
|
||||
sps1=sps1+stroka.split(',')
|
||||
|
||||
fp.close()
|
||||
|
||||
sps1
|
||||
|
||||
>> ['1', ' 2', ' 3', ' 4', '5', ' 6', ' 7', ' 8', '9', ' 10', ' 11', ' 12']
|
||||
```
|
||||
|
||||
Метод .rstrip() убирает символы с конца строки. Если не задавать аргументов,
|
||||
он удалит любые пробелы (пробел, табуляция, символы новой строки и т.п.) с конца строки.
|
||||
|
||||
Метод .replace() заменяет первый агрумент на второй. С помощью него мы убираем скобки.
|
||||
|
||||
```
|
||||
fp = open('zapis3.txt')
|
||||
|
||||
for stroka in fp:
|
||||
stroka = stroka.rstrip('\n')
|
||||
stroka = stroka.replace('[', '')
|
||||
stroka = stroka.replace(']', '')
|
||||
K = stroka.split(',')
|
||||
for i in K:
|
||||
chislo = int(i)
|
||||
sps1.append(chislo)
|
||||
|
||||
fp.close()
|
||||
|
||||
sps1
|
||||
|
||||
>> [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
|
||||
```
|
||||
|
||||
## Пункт 4.7. Чтение информации из файла с помощью метода read.
|
||||
|
||||
Этой функции передается количество символов или, если открыт бинарный файл, - количество
|
||||
байт, которое должно быть прочитано, соответственно, из текстового или бинарного файла,
|
||||
начиная с текущего положения маркера.
|
||||
|
||||
```
|
||||
fp=open('zapis3.txt')
|
||||
stroka1=fp.read(12)
|
||||
stroka2=fp.read()
|
||||
fp.close()
|
||||
|
||||
stroka1
|
||||
>> '[1, 2, 3, 4]'
|
||||
stroka2
|
||||
>> '\n[5, 6, 7, 8]\n[9, 10, 11, 12]\n'
|
||||
```
|
||||
|
||||
## 4.8. Чтение информации с помощью readline и readlines.
|
||||
|
||||
Метод readline() считывает одну строку из файла за один вызов. Он читает символы до тех пор,
|
||||
пока не встретит символ новой строки или конец файла.
|
||||
Если файл содержит только одну строку или указатель чтения находится в конце файла, то при
|
||||
вызове readline() будет возвращена пустая строка.
|
||||
|
||||
```
|
||||
fp = open('zapis3.txt')
|
||||
a = fp.readline()
|
||||
b = fp.readline()
|
||||
fp.close()
|
||||
|
||||
a
|
||||
>> '[1, 2, 3, 4]\n'
|
||||
b
|
||||
>> '[5, 6, 7, 8]\n'
|
||||
|
||||
fp=open('zapis3.txt')
|
||||
s = fp.readlines()
|
||||
s
|
||||
>> ['[1, 2, 3, 4]\n', '[5, 6, 7, 8]\n', '[9, 10, 11, 12]\n']
|
||||
```
|
||||
|
||||
## 4.9. Ввод-вывод объектов с использованием функций из модуля pickle.
|
||||
|
||||
Этот модуль предназначен для перевода объектов в бинарную форму.
|
||||
|
||||
```
|
||||
import pickle
|
||||
mnoz1={'pen','book','pen','iPhone','table','book'}
|
||||
fp=open('zapis6.mnz','wb')
|
||||
pickle.dump(mnoz1,fp)
|
||||
fp.close()
|
||||
```
|
||||
|
||||
Откроем получившийся файл в текстовом редакторе:
|
||||
|
||||
![]ris4.png
|
||||
Так происходит, потому что байты не предназначены для текстового представления.
|
||||
Они могут содержать символы, которые не могут быть интерпретированы в рамках
|
||||
текстовой кодировки.
|
||||
|
||||
```
|
||||
fp=open('zapis6.mnz','rb')
|
||||
mnoz2=pickle.load(fp)
|
||||
fp.close()
|
||||
mnoz2
|
||||
>> {'pen', 'iPhone', 'table', 'book'}
|
||||
mnoz1 == mnoz2 # автоматическое объединение повторяющихся объектов
|
||||
>> True
|
||||
|
||||
fp=open('zapis7.2ob','wb')
|
||||
pickle.dump(mnoz1,fp)
|
||||
pickle.dump(sps3,fp)
|
||||
fp.close()
|
||||
fp=open('zapis7.2ob','rb')
|
||||
obj1=pickle.load(fp)
|
||||
obj2=pickle.load(fp)
|
||||
fp.close()
|
||||
obj1
|
||||
>> {'pen', 'iPhone', 'table', 'book'}
|
||||
obj2
|
||||
>> [['Иванов И.', 1], ['Петров П.', 2], ['Сидоров С.', 3]]
|
||||
mnoz1 == obj1
|
||||
>> True
|
||||
sps3 == obj2
|
||||
>> True
|
||||
```
|
||||
|
||||
## 5. Перенаправление потоков ввода и вывода данных.
|
||||
|
||||
Поток в python позволяет регулировать источники
|
||||
ввода информации и то, куда её выводить. Всего их по умолчанию три:
|
||||
|
||||
sys.stdin — поток ввода
|
||||
sys.stdout — поток вывода
|
||||
sys.stderr — поток ошибок
|
||||
|
||||
```
|
||||
import sys
|
||||
vr_out=sys.stdout
|
||||
fc=open('Stroka.txt','w') #Откроем файл вывода
|
||||
sys.stdout=fc #Перенацеливаем стандартный поток вывода на файл
|
||||
print('запись строки в файл') #Вывод теперь будет не на экран, а в файл
|
||||
sys.stdout=vr_out #Восстановление текущего потока
|
||||
print('запись строки на экран') #Убеждаемся, что вывод на экран восстановился
|
||||
>> запись строки на экран
|
||||
fc.close()
|
||||
tmp_in = sys.stdin #Запоминаем текущий поток ввода
|
||||
fd = open("Stroka.txt", "r") #Открываем файл для ввода (чтения)
|
||||
sys.stdin = fd #Перенацеливаем ввод на файл вместо клавиатуры
|
||||
sys.stdin
|
||||
>> <_io.TextIOWrapper name='Stroka.txt' mode='r' encoding='cp1251'>
|
||||
while True:
|
||||
try:
|
||||
line = input () #Считываем из файла строку
|
||||
print(line) # Отображаем считанное
|
||||
except EOFError:
|
||||
break
|
||||
|
||||
>> запись строки в файл
|
||||
fd.close()
|
||||
sys.stdin=tmp_in #Не забыть вернуть стандартное назначение для потока ввода
|
||||
```
|
||||
|
После Ширина: | Высота: | Размер: 2.3 KiB |
|
После Ширина: | Высота: | Размер: 3.5 KiB |
|
После Ширина: | Высота: | Размер: 3.5 KiB |
|
После Ширина: | Высота: | Размер: 5.3 KiB |
@ -0,0 +1,116 @@
|
||||
## Общее контрольное задание по теме 6
|
||||
Лазарев Данил Вячеславович, А-01-23
|
||||
|
||||
## Задание
|
||||
|
||||
Придумайте инструкции и запишите их в файл с расширением .py , которые выполняют следующие операции:
|
||||
|
||||
1. Создаётся объект-кортеж со 125 целыми случайными числами из диапазона от 6 до 56, представленными в виде символьных строк.
|
||||
|
||||
2. Создаётся объект-список с вашей фамилией и 4 фамилиями ваших одноклассников.
|
||||
|
||||
3. Записывается кортеж в бинарный файл.
|
||||
|
||||
4. Записывается в этот же файл список и закрывается файл.
|
||||
|
||||
5. Открывается этот файл для чтения и считывает из него данные в 2 новых объекта.
|
||||
|
||||
6. Проверяется на совпадение новых объектов с исходными и выводится соответствующее сообщение.
|
||||
|
||||
7. Разделяется кортеж на совокупности по 5 чисел в каждой и они записываются в виде отдельных списков со своими именами.
|
||||
|
||||
## Решение
|
||||
|
||||
1
|
||||
```
|
||||
import random
|
||||
import pickle
|
||||
kort = list(range(1, 126, 1))
|
||||
print(kort)
|
||||
|
||||
>>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123, 124, 125]
|
||||
|
||||
kortrandom = ()
|
||||
for i in kort:
|
||||
kortrandom = kortrandom + (random.randint(6, 56),)
|
||||
|
||||
stroka_iz_kort = tuple(map(str, kortrandom))
|
||||
print(stroka_iz_kort)
|
||||
|
||||
|
||||
>> ('16', '54', '11', '26', '41', '11', '7', '36', '54', '55', '40', '28', '31', '38', '30', '14', '10', '41', '22', '37', '20', '33', '52', '32', '38', '40', '31', '6', '41', '37', '38', '8', '24', '32', '51', '13', '28', '40', '43', '32', '39', '40', '54', '26', '20', '36', '37', '10', '35', '35', '45', '40', '40', '15', '28', '17', '12', '43', '7', '23', '37', '31', '47', '9', '31', '11', '30', '13', '50', '46', '27', '42', '9', '24', '56', '49', '21', '44', '53', '36', '7', '13', '23', '52', '46', '50', '11', '44', '49', '33', '25', '33', '26', '18', '22', '33', '23', '33', '31', '25', '11', '11', '39', '29', '24', '10', '35', '49', '13', '21', '36', '53', '43', '8', '34', '55', '29', '38', '44', '31', '36', '35', '54', '43', '39')
|
||||
```
|
||||
2
|
||||
```
|
||||
sur = ["Лазарев", "Анисенков", "Филлипова", "Жалнин", "Мельников"]
|
||||
print("Список фамилий:", sur)
|
||||
|
||||
>> Список фамилий: ['Лазарев', 'Анисенков', 'Филлипова', 'Жалнин', 'Мельников']
|
||||
```
|
||||
3-4
|
||||
```
|
||||
f = open('bin.mnz', 'wb')
|
||||
pickle.dump(stroka_iz_kort, f)
|
||||
pickle.dump(sur, f)
|
||||
f.close()
|
||||
```
|
||||
5
|
||||
```
|
||||
f = open('bin.mnz', 'rb')
|
||||
object1 = pickle.load(f)
|
||||
object2 = pickle.load(f)
|
||||
f.close()
|
||||
print("Объект №1:",object1)
|
||||
|
||||
>> Объект №1: ('16', '54', '11', '26', '41', '11', '7', '36', '54', '55', '40', '28', '31', '38', '30', '14', '10', '41', '22', '37', '20', '33', '52', '32', '38', '40', '31', '6', '41', '37', '38', '8', '24', '32', '51', '13', '28', '40', '43', '32', '39', '40', '54', '26', '20', '36', '37', '10', '35', '35', '45', '40', '40', '15', '28', '17', '12', '43', '7', '23', '37', '31', '47', '9', '31', '11', '30', '13', '50', '46', '27', '42', '9', '24', '56', '49', '21', '44', '53', '36', '7', '13', '23', '52', '46', '50', '11', '44', '49', '33', '25', '33', '26', '18', '22', '33', '23', '33', '31', '25', '11', '11', '39', '29', '24', '10', '35', '49', '13', '21', '36', '53', '43', '8', '34', '55', '29', '38', '44', '31', '36', '35', '54', '43', '39')
|
||||
|
||||
print("Объект №2:",object2)
|
||||
|
||||
Объект №2: ['Лазарев', 'Анисенков', 'Филлипова', 'Жалнин', 'Мельников']
|
||||
```
|
||||
6
|
||||
|
||||
```
|
||||
if object1 == stroka_iz_kort and object2 == sur:
|
||||
print("Объекты идентичны исходным")
|
||||
else:
|
||||
print("Объекты отличны от изначально заданных")
|
||||
|
||||
>> Объекты идентичны исходным
|
||||
```
|
||||
7
|
||||
```
|
||||
splitkort = []
|
||||
for i in range(0, 125, 5):
|
||||
splitkort.append(list(stroka_iz_kort[i:i + 5]))
|
||||
for i in range(25):
|
||||
print(f"Список№{i + 1} = {splitkort[i]}")
|
||||
|
||||
>>
|
||||
Список№1 = ['16', '54', '11', '26', '41']
|
||||
Список№2 = ['11', '7', '36', '54', '55']
|
||||
Список№3 = ['40', '28', '31', '38', '30']
|
||||
Список№4 = ['14', '10', '41', '22', '37']
|
||||
Список№5 = ['20', '33', '52', '32', '38']
|
||||
Список№6 = ['40', '31', '6', '41', '37']
|
||||
Список№7 = ['38', '8', '24', '32', '51']
|
||||
Список№8 = ['13', '28', '40', '43', '32']
|
||||
Список№9 = ['39', '40', '54', '26', '20']
|
||||
Список№10 = ['36', '37', '10', '35', '35']
|
||||
Список№11 = ['45', '40', '40', '15', '28']
|
||||
Список№12 = ['17', '12', '43', '7', '23']
|
||||
Список№13 = ['37', '31', '47', '9', '31']
|
||||
Список№14 = ['11', '30', '13', '50', '46']
|
||||
Список№15 = ['27', '42', '9', '24', '56']
|
||||
Список№16 = ['49', '21', '44', '53', '36']
|
||||
Список№17 = ['7', '13', '23', '52', '46']
|
||||
Список№18 = ['50', '11', '44', '49', '33']
|
||||
Список№19 = ['25', '33', '26', '18', '22']
|
||||
Список№20 = ['33', '23', '33', '31', '25']
|
||||
Список№21 = ['11', '11', '39', '29', '24']
|
||||
Список№22 = ['10', '35', '49', '13', '21']
|
||||
Список№23 = ['36', '53', '43', '8', '34']
|
||||
Список№24 = ['55', '29', '38', '44', '31']
|
||||
Список№25 = ['36', '35', '54', '43', '39']
|
||||
```
|
||||
|
||||
@ -0,0 +1,45 @@
|
||||
#1.
|
||||
import random
|
||||
import pickle
|
||||
kort = list(range(1, 126, 1))
|
||||
print(kort)
|
||||
|
||||
kortrandom = ()
|
||||
for i in kort:
|
||||
kortrandom = kortrandom + (random.randint(6, 56),)
|
||||
|
||||
stroka_iz_kort = tuple(map(str, kortrandom))
|
||||
print(stroka_iz_kort)
|
||||
#2.
|
||||
|
||||
sur = ["Лазарев", "Анисенков", "Филлипова", "Жалнин", "Мельников"]
|
||||
print("Список фамилий:", sur)
|
||||
#3-4
|
||||
|
||||
f = open('bin.mnz', 'wb')
|
||||
pickle.dump(stroka_iz_kort, f)
|
||||
pickle.dump(sur, f)
|
||||
f.close()
|
||||
#5.
|
||||
|
||||
f = open('bin.mnz', 'rb')
|
||||
object1 = pickle.load(f)
|
||||
object2 = pickle.load(f)
|
||||
f.close()
|
||||
print("Объект №1:",object1)
|
||||
print("Объект №2:",object2)
|
||||
|
||||
#6.
|
||||
|
||||
if object1 == stroka_iz_kort and object2 == sur:
|
||||
print("Объекты идентичны исходным")
|
||||
else:
|
||||
print("Объекты отличны от изначально заданных")
|
||||
#7.
|
||||
|
||||
splitkort = []
|
||||
for i in range(0, 125, 5):
|
||||
splitkort.append(list(stroka_iz_kort[i:i + 5]))
|
||||
for i in range(25):
|
||||
print(f"Список№{i + 1} = {splitkort[i]}")
|
||||
|
||||
@ -0,0 +1,3 @@
|
||||
[1, 2, 3, 4]
|
||||
[5, 6, 7, 8]
|
||||
[9, 10, 11, 12]
|
||||
@ -0,0 +1 @@
|
||||
Иванов И. 1Петров П. 2Сидоров С. 3
|
||||
@ -0,0 +1,3 @@
|
||||
. 1
|
||||
. 2
|
||||
. 3
|
||||
@ -0,0 +1,3 @@
|
||||
Иванов И. 1
|
||||
Петров П. 2
|
||||
Сидоров С. 3
|
||||
Двоичный файл не отображается.
Двоичный файл не отображается.
Загрузка…
Ссылка в новой задаче