diff --git a/TEMA6/fig1.png b/TEMA6/fig1.png new file mode 100644 index 0000000..d6c5f1e Binary files /dev/null and b/TEMA6/fig1.png differ diff --git a/TEMA6/report.md b/TEMA6/report.md new file mode 100644 index 0000000..1f287d4 --- /dev/null +++ b/TEMA6/report.md @@ -0,0 +1,268 @@ +# Отчет по теме 6 + +**Антонов Дмитрий, А-03-23** + +### 1.Начало работы, настройка текущего каталога +```py +import os +os.chdir('//Users//dmitrijantonov//Desktop//POAC//python-labs//TEMA6//') +``` + +### 2.Вывод данных на экран дисплея +#### 2.1 Эхо-вывод +```py +stroka='Автоматизированная система управления' +stroka +'Автоматизированная система управления' +``` + +#### 2.2 print вывод +```py +fff=234.5;gg='Значение температуры = ' +print(gg, fff) #Можно вывести несколько объектов за одно обращение к функции +Значение температуры = 234.5 +print(gg, fff, sep='/') +Значение температуры = /234.5 +print(gg, fff,sep='/',end='***'); print('____') +Значение температуры = /234.5***____ +print() +print(""" Здесь может выводиться +большой текст, +занимающий несколько строк""") + Здесь может выводиться +большой текст, +занимающий несколько строк +print("Здесь может выводиться", + "большой текст,", + "занимающий несколько строк") +Здесь может выводиться большой текст, занимающий несколько строк +``` +#### 2.3 Стандартный поток вывода, модуль sys +```py +import sys +sys.stdout.write('Функция write') +Функция write13 +sys.stdout.write('Функция write\n') +Функция write +14 +help(sys.stdout.write) +Help on method write in module idlelib.run: + +write(s) method of idlelib.run.StdOutputFile instance + Write string s to stream. + + Return the number of characters written + (which is always equal to the length of the string). +``` +### 3. Ввод c клавиатуры +```py +psw=input('Введите пароль:') +Введите пароль:555550 +psw +'555550' +type(psw) + +while True: + znach=float(input('Задайте коэф.усиления = ')) + if znach<17.5 or znach>23.8: + print('Ошибка!') + else: + break + +Задайте коэф.усиления = 15.4 +Ошибка! +Задайте коэф.усиления = 21.6 +import math +print(eval(input('введите выражение для расчета = '))) +введите выражение для расчета = math.log10(23/(1+math.exp(-3.24))) +1.34504378689765 +``` +### 4.Ввод-вывод при работе с файлами +#### 4.1 Функции для работы с путем к файлу +- Настройка текущей директории +```py +import os +os.getcwd() +'/Users/dmitrijantonov/Desktop/POAC/python-labs/TEMA6' +Antonov = os.getcwd() +print(Antonov) +/Users/dmitrijantonov/Desktop/POAC/python-labs/TEMA6 +os.getcwd() +'/Users/dmitrijantonov/Desktop/POAC/python-labs/TEMA6' +``` +- Пробую методы вложенного модуля path +```py +os.listdir() +['.DS_Store', 'hm', 'report.md', '.gitkeep'] +os.path.isdir('/Users/dmitrijantonov/Desktop/POAC/python-labs/TEMA6') +True +os.path.isdir('python-labs/TEMA6') +False +os.path.abspath('report.md') +'/Users/dmitrijantonov/Desktop/POAC/python-labs/TEMA6/report.md' +file = os.path.abspath('report.md') +drkt=os.path.dirname(file) +drkt +'/Users/dmitrijantonov/Desktop/POAC/python-labs/TEMA6' +os.path.basename(file) +'report.md' +os.path.split(file) +('/Users/dmitrijantonov/Desktop/POAC/python-labs/TEMA6', 'report.md') +os.path.exists(file) +True +os.path.exists(file+'eee') +False +``` +#### 4.3 Открытие/закрытие файла, функция open/close +```py +help(open) +fp=open(file=drkt+'//zapis1.txt',mode='w') +drkt +'/Users/dmitrijantonov/Desktop/POAC/python-labs/TEMA6' +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'] +fp.close() +``` +#### 4.4 Запись в файл функция write +```py +sps=list(range(1,13)) +fp2=open('zapis3.txt','w') +fp2.write(str(sps[:4])+'\n');fp2.write(str(sps[4:8])+'\n');fp2.write(str(sps[8:])+'\n');fp2.close() +13 +13 +16 +``` +[!Данные записанные в файл](fig1.png) +- Запись списка списков +```py +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() + +gh=open('zapis5.txt','w') +for r in sps3: + gh.write(r[0]+' '+str(r[1])+'\n') +12 +12 +13 +gh.close() +``` +#### 4.5 Чтение информации из текстового файла. +```py +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() +print(sps1) +['1', ' 2', ' 3', ' 4', '5', ' 6', ' 7', ' 8', '9', ' 10', ' 11', ' 12'] +``` +- Теперь элементы списков совпадают +```py +for i in range(len(sps1)): + sps1[i] = int(sps1[i]) +sps1==sps +True +``` +#### 4.6 Чтение информации из файла с помощью метода read +```py +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' +``` +- Изучение функции readline и readlines +```py +fp=open('zapis3.txt');stroka1=fp.readline() +stroka1 +'[1, 2, 3, 4]\n' + +stroka2=fp.readline(3) +stroka2 +'[5,' +fp.close() + +fp=open('zapis3.txt');stroka1=fp.readlines() +stroka1 +['[1, 2, 3, 4]\n', '[5, 6, 7, 8]\n', '[9, 10, 11, 12]\n'] +fp.close() +``` +#### 4.9 Ввод-вывод объектов с использованием функций из модуля pickle +```py +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() +``` +- Проверка объектов на совпадение +```py +mnoz2 == mnoz1 +True +``` +- Отличие от исходного в том, что сохранились только уникальные элементы +```py +mnoz2 +{'table', 'book', 'iPhone', 'pen'} +mnoz1 +{'table', 'book', 'iPhone', 'pen'} +``` +- Запись/чтение нескольких объектов +```py +sps3 +[['Иванов И.', 1], ['Петров П.', 2], ['Сидоров С.', 3]] +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,obj2 +({'table', 'book', 'iPhone', 'pen'}, [['Иванов И.', 1], ['Петров П.', 2], ['Сидоров С.', 3]]) +obj1==mnoz1; obj2==sps3 +True +True +``` +### 5. Перенаправление потоков ввода и вывода данных +- Перенаправление вывода в файл +```py +import sys +vr_out=sys.stdout +fc=open('Stroka.txt','w') +sys.stdout=fc +print('запись строки в файл') +sys.stdout=vr_out +print('запись строки на экран') +запись строки на экран +fc.close() +``` +- Перенаправление вввода из файла +```py +tmp_in = sys.stdin +fd = open("Stroka.txt", "r") +sys.stdin = fd +while True: + try: + line = input () + print(line) + except EOFError: + break +запись строки в файл +fd.close() +sys.stdin=tmp_in +``` \ No newline at end of file diff --git a/TEMA6/task.md b/TEMA6/task.md new file mode 100644 index 0000000..195d9c7 --- /dev/null +++ b/TEMA6/task.md @@ -0,0 +1,42 @@ +# Общее контрольное задание по теме 6 + +**Антонов Дмитрий, А-03-23** +1. Создаётся объект-кортеж со 125 целыми случайными числами из диапазона от 6 до 56, пред-ставленными в виде символьных строк. +```py +import random as rn +kort = tuple(str(rn.randint(6,56)) for _ in range(126)) +kort +('29', '20', '18', '11', '20', '38', '8', '15', '33', '28', '30', '24', '50', '15', '26', '13', '36', '38', '10', '23', '36', '34', '16', '30', '34', '55', '28', '34', '36', '16', '6', '14', '15', '51', '7', '14', '10', '12', '54', '16', '53', '16', '39', '39', '32', '53', '43', '27', '8', '38', '8', '30', '31', '31', '22', '40', '40', '42', '18', '23', '20', '14', '48', '56', '27', '39', '10', '6', '47', '51', '26', '42', '54', '38', '49', '24', '21', '43', '40', '36', '50', '41', '43', '23', '34', '26', '21', '54', '35', '27', '10', '32', '53', '40', '39', '38', '6', '51', '37', '41', '39', '26', '46', '6', '13', '22', '26', '24', '20', '11', '34', '29', '27', '17', '23', '36', '25', '17', '25', '6', '55', '24', '52', '17', '48', '40') +``` +2. Создаётся объект-список с вашей фамилией и 4 фамилиями ваших одноклассников. +```py +spis = ['Антонов','Ефимова','Турханов','Девятова','Гордиевских'] +``` +3. Записывается кортеж и список в бинарный файл. +```py +import pickle +fp=open('task.bn','wb') +pickle.dump(kort,fp) +pickle.dump(spis,fp) +fp.close() +fp=open('task.bn','rb') +obj1=pickle.load(fp) +obj2=pickle.load(fp) +fp.close() +obj1 == kort; obj2 == spis +True +True +obj1 +('29', '20', '18', '11', '20', '38', '8', '15', '33', '28', '30', '24', '50', '15', '26', '13', '36', '38', '10', '23', '36', '34', '16', '30', '34', '55', '28', '34', '36', '16', '6', '14', '15', '51', '7', '14', '10', '12', '54', '16', '53', '16', '39', '39', '32', '53', '43', '27', '8', '38', '8', '30', '31', '31', '22', '40', '40', '42', '18', '23', '20', '14', '48', '56', '27', '39', '10', '6', '47', '51', '26', '42', '54', '38', '49', '24', '21', '43', '40', '36', '50', '41', '43', '23', '34', '26', '21', '54', '35', '27', '10', '32', '53', '40', '39', '38', '6', '51', '37', '41', '39', '26', '46', '6', '13', '22', '26', '24', '20', '11', '34', '29', '27', '17', '23', '36', '25', '17', '25', '6', '55', '24', '52', '17', '48', '40') +obj2 +['Антонов', 'Ефимова', 'Турханов', 'Девятова', 'Гордиевских'] +if(obj1 == kort and obj2 == spis): + print("Объекты схожи") +Объекты схожи +``` +4. Разделяется кортеж на совокупности по 5 чисел в каждой и они записываются в виде отдельных списков со своими именами. +```py +vocab = {} +for i in range(0,len(kort),5): + vocab['группа №'+str(i//5)] = list(kort[i:i+5]) +``` \ No newline at end of file diff --git a/TEMA6/test.md b/TEMA6/test.md new file mode 100644 index 0000000..0a44543 --- /dev/null +++ b/TEMA6/test.md @@ -0,0 +1,48 @@ +# Индивидуальное контрольное задание по теме 6 + +**Антонов Дмитрий, А-03-23** + +## Задание M2_8 + +1) Создайте множество с 40 элементами - случайными числами, равномерно распределенными на интервале от -20 до +10. Числа должны быть округлены до двух знаков после точки. +```py +import os +os.chdir('//Users//dmitrijantonov//Desktop//POAC//python-labs//TEMA6//') +import random as rn +my_set = set(round(rn.uniform(-20,10),2) for _ in range(40)) +my_set +{0.41, 2.22, 3.89, 4.77, 5.04, 6.94, 7.43, 8.16, 9.13, 9.48, 9.85, 6.01, 9.2, -3.82, -19.36, -18.72, -15.84, -9.36, -9.5, -8.1, -4.59, -19.23, -4.49, -4.15, -16.02, -4.74, -16.5, -13.96, -12.95, -11.92, -10.71, -9.89, -8.66, -7.45, -6.18, -5.86, -4.62, -3.52, -2.95, -1.4} +type(my_set) + +``` +2) Запросите у пользователя и введите имя бинарного файла для сохранения множества. Если во введенном имени есть пробелы, замените их на пустые строки. +```py +name = input("Введите имя бинарного файла для сохранения множества: ").replace(" ","") +Введите имя бинарного файла для сохранения множества: NA ME +name +'NAME' +``` +3) Запишите множество в бинарный файл с указанным именем. +```py +import pickle +fl = open(name+"bn",'wb') +pickle.dump(my_set,fl) +fl.close() +``` +4) Удалите из памяти созданное множество. +```py +del(my_set) +``` +5) Прочитайте множество из файла и рассчитайте по его элементам среднее значение. Отобразите его на экране по шаблону: " По <число элементов> среднее = <рассчитанное значение>". Выводимое среднее округлить до двух знаков после точки. +```py +fl = open(name+"bn",'rb') +file_set = pickle.load(fl) +file_set +{0.41, 2.22, 3.89, 4.77, 5.04, 6.94, 7.43, 8.16, 9.13, 9.48, 9.85, 6.01, 9.2, -7.45, -4.62, -3.52, -9.36, -9.89, -8.66, -6.18, -4.49, -19.36, -18.72, -19.23, -4.15, -15.84, -16.02, -4.74, -16.5, -13.96, -12.95, -9.5, -8.1, -11.92, -10.71, -5.86, -4.59, -3.82, -2.95, -1.4} +import numpy +mn = numpy.mean(list(file_set)) +mn +np.float64(-4.2989999999999995) +print("По {} среднее = {} ".format(len(file_set),round(mn,2))) +По 40 среднее = -4.30 +``` \ No newline at end of file