From 12e60c424fe9ba88fb4cd562a8719bcaf71617dd Mon Sep 17 00:00:00 2001 From: Danil Date: Thu, 20 Nov 2025 23:58:27 +0300 Subject: [PATCH] =?UTF-8?q?report:=D0=B4=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- TEMA6/Stroka.txt | 1 + TEMA6/bin.mnz | Bin 0 -> 743 bytes TEMA6/protocol6.md | 491 +++++++++++++++++++++++++++++++++++ TEMA6/protocol6.py | 609 ++++++++++++++++++++++++++++++++++++++++++++ TEMA6/protocol6.txt | 481 ++++++++++++++++++++++++++++++++++ TEMA6/ris1.png | Bin 0 -> 2361 bytes TEMA6/ris2.png | Bin 0 -> 3584 bytes TEMA6/ris3.png | Bin 0 -> 3534 bytes TEMA6/ris4.png | Bin 0 -> 5448 bytes TEMA6/task.md | 116 +++++++++ TEMA6/task6.py | 45 ++++ TEMA6/zapis1.txt | 0 TEMA6/zapis2.bin | 0 TEMA6/zapis3.txt | 3 + TEMA6/zapis4.txt | 1 + TEMA6/zapis5.md | 3 + TEMA6/zapis5.txt | 3 + TEMA6/zapis6.mnz | Bin 0 -> 46 bytes TEMA6/zapis7.2ob | Bin 0 -> 139 bytes 19 files changed, 1753 insertions(+) create mode 100644 TEMA6/Stroka.txt create mode 100644 TEMA6/bin.mnz create mode 100644 TEMA6/protocol6.md create mode 100644 TEMA6/protocol6.py create mode 100644 TEMA6/protocol6.txt create mode 100644 TEMA6/ris1.png create mode 100644 TEMA6/ris2.png create mode 100644 TEMA6/ris3.png create mode 100644 TEMA6/ris4.png create mode 100644 TEMA6/task.md create mode 100644 TEMA6/task6.py create mode 100644 TEMA6/zapis1.txt create mode 100644 TEMA6/zapis2.bin create mode 100644 TEMA6/zapis3.txt create mode 100644 TEMA6/zapis4.txt create mode 100644 TEMA6/zapis5.md create mode 100644 TEMA6/zapis5.txt create mode 100644 TEMA6/zapis6.mnz create mode 100644 TEMA6/zapis7.2ob diff --git a/TEMA6/Stroka.txt b/TEMA6/Stroka.txt new file mode 100644 index 0000000..48d3f7e --- /dev/null +++ b/TEMA6/Stroka.txt @@ -0,0 +1 @@ + diff --git a/TEMA6/bin.mnz b/TEMA6/bin.mnz new file mode 100644 index 0000000000000000000000000000000000000000..42cd8c7e2510acf81179ce2f622c5cd80bbb0582 GIT binary patch literal 743 zcmX|(GVi`5FS zpcLjH#X%!Q&jKQIScOz%j~WfcKU+)qS6jiqrbYp>6VZ#4f=xjqL~>Uk_X|b^Wz1t$ zSpX;*lLg3(rVlqn>I-a)<*qDj9i36luvEpU;8>rnE=IK~LmKPji;s0^L_#(TLyBrB ztKWm9z{FG3H#+vu{h{5R9_nYex$pPgrJZfCZyT1@zU;H_uI$xj8 +#А-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) +>> +``` + +Пример 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 "", line 1, in + 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) + +>> +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 #Не забыть вернуть стандартное назначение для потока ввода +``` diff --git a/TEMA6/protocol6.py b/TEMA6/protocol6.py new file mode 100644 index 0000000..b38eeae --- /dev/null +++ b/TEMA6/protocol6.py @@ -0,0 +1,609 @@ +# Отчет по теме 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) +>> +``` + + +``` +# Пример 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\\OneDrive\\Рабочий стол\\python-labs\\TEMA5' +Lazarev = os.getcwd() +Lazarev +'C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6' + +os.chdir(r"C:\Users\denvo\OneDrive\Рабочий стол\python-labs\TEMA6") +os.getcwd() +'C:\\Users\\denvo\\OneDrive\\Рабочий стол\\python-labs\\TEMA6' + + +#Изучение функции mkdir +help(os.mkdir) +Help on built-in function mkdir in module nt: + +mkdir(path, mode=511, *, dir_fd=None) + Create a directory. + + If dir_fd is not None, it should be a file descriptor open to a directory, + and path should be relative; path will then be relative to that directory. + dir_fd may not be implemented on your platform. + If it is unavailable, using it will raise a NotImplementedError. + + The mode argument is ignored on Windows. Where it is used, the current umask + value is first masked out. + +os.chdir("mod2") +os.getcwd() +'C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\mod2' + + +#Удаление каталога +>>> help(os.rmdir) +Help on built-in function rmdir in module nt: + +rmdir(path, *, dir_fd=None) + Remove a directory. + + If dir_fd is not None, it should be a file descriptor open to a directory, + and path should be relative; path will then be relative to that directory. + dir_fd may not be implemented on your platform. + If it is unavailable, using it will raise a NotImplementedError. + + +>>> os.rmdir('C:\\Users\\denvo\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\mod2') +Traceback (most recent call last): + File "", line 1, in + os.rmdir('C:\\Users\\denvo\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\mod2') +PermissionError: [WinError 32] Процесс не может получить доступ к файлу, так как этот файл занят +другим процессом: 'C:\\Users\\denvo\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\mod2' + +>>> os.getcwd() +'d:\\STUDY\\LVL3\\Программное обеспечение автоматизированных систем\\Тема6\\testdir' +>>> os.chdir('../') +>>> os.getcwd() +'C:\\Users\\denvo\\OneDrive\\Рабочий стол\\python-labs\\TEMA6' +>>> os.rmdir("mod2") + +>>> os.rmdir("mod2") +Traceback (most recent call last): + File "", line 1, in + os.rmdir("mod2") +FileNotFoundError: [WinError 2] Не удается найти указанный файл: 'mod2' + + +#Показать список всех файлов и папок, вложенных в текущую +>>> help(os.listdir) +Help on built-in function listdir in module nt: + +listdir(path=None) + Return a list containing the names of the files in the directory. + + path can be specified as either str, bytes, or a path-like object. If path is bytes, + the filenames returned will also be bytes; in all other circumstances + the filenames returned will be str. + If path is None, uses the path='.'. + On some platforms, path may also be specified as an open file descriptor;\ + the file descriptor must refer to a directory. + If this functionality is unavailable, using it raises NotImplementedError. + + The list is in arbitrary order. It does not include the special + entries '.' and '..' even if they are present in the directory. + +>>> os.chdir(r'C:\\Users\\denvo\\OneDrive\\Рабочий стол\\python-labs\\TEMA6') +>>> os.listdir() +['.gitkeep', 'report.md'] + + +#Проверка существования каталога +>>> 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("report.md") +False +>>> os.path.isdir("фото") +False + + +#Возвращение абсолютного пути +>>> fil = os.path.abspath("report.md") +>>> fil +'C:\\Users\\Dannyan\\AppData\\Local\\Programs\\Python\\Python313\\report.md' +fil=os.path.abspath("oplata.dbf") +fil +'C:\\Users\\Dannyan\\AppData\\Local\\Programs\\Python\\Python313\\oplata.dbf' + +#Отделение из абсолютного пути только каталога/только имени файла +drkt = os.path.dirname(fil) +drkt +'C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6' + +b = os.path.basename(fil) +print(b) +'report.md' + + +#Разделение на кортеж из пути и из имени файла +os.path.split(fil) +('C:\\Users\\Dannyan\\OneDrive\\Рабочий стол\\python-labs\\TEMA6', 'report.md') +type(os.path.split(fil)) + + + +#Проверка существования любого объекта +os.path.exists("C:/Games") +True +os.path.exists("C:/Money") +False + + +#Проверка существования файла +>>> os.path.isfile("C:/Users/denvo/OneDrive/Рабочий стол/python-labs/TEMA6/report.md") +True +>>> os.path.isfile("C:/Users/denvo/OneDrive/Рабочий стол/python-labs/") +False +>>> os.path.isfile("D:/Фото/me.jpg") +False +``` + +## Пункт 4.2 Общая схема работы с файлом + +Для обмена данными с файлом необходимо выполнить следующие операции: + +• Открытие файла с указанием его имени и цели (чтение, запись, добавление данных); + +• Выполнение одной или нескольких операций обмена данными с файлом; + +• Закрытие файла. + +## Пункт 4.3 Открытие файла для записи или чтения + +``` +>>> fp = open(file = drkt+'\\zapis1.txt', mode='w') +>>> type(fp) + +>>> fp +<_io.TextIOWrapper name='C:\\Users\\denvo\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\zapis1.txt' mode='w' encoding='cp1251'> +>>> fp.closed +False + +>>> dir(fp) +['_CHUNK_SIZE', '__class__', '__del__', '__delattr__', '__dict__', '__dir__', '__doc__', + '__enter__', '__eq__', '__exit__', '__format__', '__ge__', '__getattribute__', '__gt__', + '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__lt__', '__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'] +``` + +Здесь перечислены атрибуты объекта: + name - абсолютный путь + mode - режим: + r - чтение + w - запись (если такой файл уже есть, его содержимое будет удалено, если нет, + создается. Содержимое удаляется в момент открытия, а не в момент первой + записи) + a - дозапись (в конец) + x - открывает для записи, но только если файл есть, иначе FileExistsError. + + - чтение и запись: + r+ - чтение и запись, файл должен существовать. + w+ - запись и чтение, файл создаётся или перезаписывается. + a+ - добавление и чтение, файл создаётся, если не существует. + + rb, wb, ab, xb - все то же, но в бинарном режиме (читаются байты) + + encoding - кодировка: + В Windows в консоли по умолчанию cp1251 или cp1252 в зависимости от языка системы. + В файлах чаще UTF-8 + Linux, MacOS - UTF-8. + + Еще есть атрибут-флаг closed: True, если файл закрыт, False, если открыт. + +Если имя файла на первом месте, а режим на втором, то имена можно не указывать. (позиционные аргументы +всегда должны идти первыми, а именованные — после них) +Путь можно опустить, если он совпадает с текущей рабочей директории: + +``` +>>> fp = open('zapis1.txt','w') +>>> fp +<_io.TextIOWrapper name='zapis1.txt' mode='w' encoding='cp1251'> + + +#Пример открытия бинарного файла +>>> fp1 = open(drkt + '\\zapis2.bin', mode = 'wb+') +>>> fp1 +<_io.BufferedRandom name='C:\\Users\\denvo\\OneDrive\\Рабочий стол\\python-labs\\TEMA6\\zapis2.bin'> +``` + +## Пункт 4.4. Закрытие файла. + +Когда файл успешно открывается / создается и открывается, ему задается целочисленный +номер, называемый файловым дескриптором. Он создается только на один сеанс работы и указывает, +с каким именно файлом нужно работать. + +После того, как программа отработала, надо очистить ресурсы, связанные с файлом (область +в оперативной памяти, в буфере при буферизации), и удалить дескриптор. Если не закрыть +файл, это может его повредить, данные могут быть утеряны или система может быть перегружена, +т.к. исчерпается ресурс оперативной памяти. Для закрытия есть метод close(). + +``` +>>> fp.close() +>>> fp +<_io.TextIOWrapper name='zapis1.txt' mode='w' encoding='cp1251'> +>>> fp.closed +True +``` + +## Пункт 4.5. Запись информации в файл. + +``` +>>> help(fp.write) +Help on built-in function write: + +write(text, /) method of _io.TextIOWrapper instance + Write string to stream. + Returns the number of characters written (which is always equal to + the length of the string). + +>>> sps = list(range(1,13)) +>>> sps +[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12] +>>> 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() +``` + +Посмотрим, как выглядит файл, в текстовом редакторе: + +[1, 2, 3, 4] + +[5, 6, 7, 8] + +[9, 10, 11, 12] + +В файл записались преобразованные в строки срезы списка. Второй и последущие вызовы write() +в рамках одного сеанса не стирают содержимое файла. +Метод выполняет действия по записи данных в файл, но возвращает количество записанных +символов. + +``` +>>> sps3 = [['Иванов И.',1],['Петров П.',2],['Сидоров С.',3]] +>>> 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() +``` + +Файл в текстовом редакторе выглядит так: + +Иванов И. 1Петров П. 2Сидоров С. 3 + +Видно, что строки склеились там, где не надо. Попробуем по-другому. + +``` +>>> gh = open('zapis5.txt','w') +>>> for r in sps3: + gh.write(r[0] + ' '+str(r[1]) + '\n') + +12 +12 +13 +>>> gh.close() +``` + +Мы добавили перенос каретки на каждой итерации цикла и пробел в нужном месте. Стало так: + +Иванов И. 1 + +Петров П. 2 + +Сидоров С. 3 + + +## Пункт 4.6. Чтение из файла, способ 1. + +``` +>>> sps1 = [] +>>> fp = open('zapis3.txt') +>>> for stroka in fp: + stroka = stroka.rstrip('\n') + stroka = stroka.replace('[','') + stroka = stroka.replace(']','') + sps1 = sps1 + stroka.split(',') +``` + +Метод .rstrip() убирает символы с конца строки. Если не задавать аргументов, +он удалит любые пробелы (пробел, табуляция, символы новой строки и т.п.) с конца строки. + +Метод .replace() заменяет первый агрумент на второй. С помощью него мы убираем скобки. + +``` +>>> fp.close() +>>> sps1 +['1', ' 2', ' 3', ' 4', '5', ' 6', ' 7', ' 8', '9', ' 10', ' 11', ' 12'] +>>> sps2 = [int(i.strip()) for i in sps1] +>>> sps2 +[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12] +``` + +## Пункт 4.7. Чтение информации из файла с помощью метода read. + +Этой функции передается количество символов или, если открыт бинарный файл, - количество +байт, которое должно быть прочитано, соответственно, из текстового или бинарного файла, +начиная с текущего положения маркера. Если указать число большее, чем длина файла, +или любое отрицательное, или не передавать вообще, будет прочитан весь файл до EOF. + +``` +>>> 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() считывает одну строку из файла за один вызов. Он читает символы до тех пор, +пока не встретит символ новой строки (\n; включается в строку) или конец файла (EOF). +Если файл содержит только одну строку или указатель чтения находится в конце файла, то при +вызове readline() будет возвращена пустая строка. + +Метод readlines() считывает все строки файла и возвращает их в виде списка, где каждая +строка — это отдельный элемент списка. Каждая строка в списке будет содержать символ новой +строки \n, если он есть в файле. + +``` +>>> file = open("zapis5.txt") +>>> file.readline() +'Иванов И. 1\n' +>>> file.seek(0) +0 +>>> file.readlines() +['Иванов И. 1\n', 'Петров П. 2\n', 'Сидоров С. 3\n'] +``` + +## Пункт 4.9. Ввод-вывод объектов с использованием функций из модуля pickle. + +Этот модуль предназначен для перевода объектов в бинарную форму. + +``` +>>> import pickle +>>> mnoz1={'book', 'iPhone', 'table', 'pen'} +>>> fp = open('zapis6.mnz', 'wb') +>>> pickle.dump(mnoz1, fp) +>>> fp.close() +``` + +Откроем получившийся файл в текстовом редакторе, увидим подобную строку. + +Ђ•# Џ”(Њbook”ЊiPhone”Њtable”Њpen”ђ. + +Так происходит, потому что байты в этом файле не предназначены для текстового представления. +Они могут содержать символы, которые не могут быть корректно интерпретированы в рамках +любой текстовой кодировки. Но в некоторых байтах содержатся символы, которые попадают в +диапазон, поддерживаемый текстовым редактором и конкретной кодировкой (в моем случае ANSI), +поэтому правильно дешифрованные буквы все же есть. + +``` +>>> fp = open('zapis6.mnz','rb') +>>> mnoz2 = pickle.load(fp) +>>> fp.close() +>>> mnoz2 +{'book', 'iPhone', 'table', 'pen'} +>>> 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 +{'book', 'iPhone', 'table', 'pen'} +>>> obj2 +[['Иванов И.', 1], ['Петров П.', 2], ['Сидоров С.', 3]] +>>> mnoz1 == obj1 +True +>>> obj2 == sps3 +True +``` + +## Пункт 5. Перенаправление потоков ввода и вывода данных. + +Поток в python - это абстракция, которая позволяет регулировать источники +ввода информации и то, куда её выводить. Всего их по умолчанию три: + +sys.stdin — поток ввода + +sys.stdout — поток вывода + +sys.stderr — поток ошибок + +``` +>>> import sys + +#Сохраним адрес в памяти текущего потока вывода: +>>> vr_out = sys.stdout +>>> vr_out + + +#Откроем файл на запись: +>>> fc = open('Stroka.txt','w') + +#Теперь зададим в качестве потока вывода этот файл: +>>> sys.stdout = fc +>>> print('запись строки в файл') + +>>> sys.stdout = vr_out +>>> print('запись строки на экран') +запись строки на экран +>>> fc.close() +``` + +В файле Stroka.txt находится: запись строки в файл + +Можно перенаправить и поток ввода тоже. Например, на файл: + +``` +>>> 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 +``` diff --git a/TEMA6/protocol6.txt b/TEMA6/protocol6.txt new file mode 100644 index 0000000..6c1bb8f --- /dev/null +++ b/TEMA6/protocol6.txt @@ -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) +>> +``` + + +``` +# Пример 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 "", line 1, in + 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) + +>> +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 #Не забыть вернуть стандартное назначение для потока ввода +``` diff --git a/TEMA6/ris1.png b/TEMA6/ris1.png new file mode 100644 index 0000000000000000000000000000000000000000..8bbcd58158ed68007be1d17adce3d3c5828fb20d GIT binary patch literal 2361 zcmb7Fdo*v0IKn=f6L1|+f!)AY{&de#hePfBVx_4cHahm&MwoiUoGKYx6m69HDt z$|p^L4}iKBAd*N1zyN&95kLY22>m8LL|K&-76OTtTW*RZ0$>QR

gx0H8wZK*}cJ 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 literal 0 HcmV?d00001 diff --git a/TEMA6/ris3.png b/TEMA6/ris3.png new file mode 100644 index 0000000000000000000000000000000000000000..dae16557aec49b1510ae942bbf01ec53bb77c4c7 GIT binary patch literal 3534 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 HpT7PNRezhU literal 0 HcmV?d00001 diff --git a/TEMA6/ris4.png b/TEMA6/ris4.png new file mode 100644 index 0000000000000000000000000000000000000000..0827a81b5ee14ffeaa10d24fc8cfe715947a07b6 GIT binary patch literal 5448 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 literal 0 HcmV?d00001 diff --git a/TEMA6/task.md b/TEMA6/task.md new file mode 100644 index 0000000..7af9a6c --- /dev/null +++ b/TEMA6/task.md @@ -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'] +``` + diff --git a/TEMA6/task6.py b/TEMA6/task6.py new file mode 100644 index 0000000..83c3926 --- /dev/null +++ b/TEMA6/task6.py @@ -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]}") + diff --git a/TEMA6/zapis1.txt b/TEMA6/zapis1.txt new file mode 100644 index 0000000..e69de29 diff --git a/TEMA6/zapis2.bin b/TEMA6/zapis2.bin new file mode 100644 index 0000000..e69de29 diff --git a/TEMA6/zapis3.txt b/TEMA6/zapis3.txt new file mode 100644 index 0000000..8132aa8 --- /dev/null +++ b/TEMA6/zapis3.txt @@ -0,0 +1,3 @@ +[1, 2, 3, 4] +[5, 6, 7, 8] +[9, 10, 11, 12] diff --git a/TEMA6/zapis4.txt b/TEMA6/zapis4.txt new file mode 100644 index 0000000..edd0c45 --- /dev/null +++ b/TEMA6/zapis4.txt @@ -0,0 +1 @@ + . 1 . 2 . 3 \ No newline at end of file diff --git a/TEMA6/zapis5.md b/TEMA6/zapis5.md new file mode 100644 index 0000000..ba2ed24 --- /dev/null +++ b/TEMA6/zapis5.md @@ -0,0 +1,3 @@ + . 1 + . 2 + . 3 diff --git a/TEMA6/zapis5.txt b/TEMA6/zapis5.txt new file mode 100644 index 0000000..ecde2d7 --- /dev/null +++ b/TEMA6/zapis5.txt @@ -0,0 +1,3 @@ + . 1 + . 2 + . 3 diff --git a/TEMA6/zapis6.mnz b/TEMA6/zapis6.mnz new file mode 100644 index 0000000000000000000000000000000000000000..840de238cbee5cc39121240017a6bdf9f9d78c36 GIT binary patch literal 46 wcmZo*nX1eH0sT`ndYB7R^QQE$Wd>yA=cP{RVJ%5a$^p_WN%{HNQzqyE05MSyF#rGn literal 0 HcmV?d00001 diff --git a/TEMA6/zapis7.2ob b/TEMA6/zapis7.2ob new file mode 100644 index 0000000000000000000000000000000000000000..7914751056d05cd2d7aa4c28ef5015fa22eb01c1 GIT binary patch literal 139 zcmZo*nX1eH0sT`ndYB7R^QQE$Wd>yA=cP{RVJ%5a$^p_WN%{HNQzqy&uuKhts*ata z0Yp6l7iL`8bYa7Vy%+Xf*rae_hTar!##D&J{0mzzHeGChNX!RHFo7k6E-bvT