форкнуто от main/python-labs
Родитель
2cf7e731d1
Сommit
7dc5269479
@ -0,0 +1,378 @@
|
||||
# Отчёт по теме 4
|
||||
Зеленкина Катерина Михайловна, А-02-23
|
||||
|
||||
## Пункт 1. Запуск IDLE
|
||||
## Пункт 2. Стандартные функции
|
||||
### Пункт 2.1. Функция round
|
||||
__round__ - округление числа с заданной точностью.
|
||||
|
||||
```py
|
||||
>>> help(round)
|
||||
Help on built-in function round in module builtins:
|
||||
|
||||
round(number, ndigits=None)
|
||||
Round a number to a given precision in decimal digits.
|
||||
|
||||
The return value is an integer if ndigits is omitted or None. Otherwise
|
||||
the return value has the same type as the number. ndigits may be negative.
|
||||
|
||||
>>> a=round(123.456,1); a; type(a)
|
||||
123.5
|
||||
<class 'float'>
|
||||
>>> b=round(123.456,0); b; type(b)
|
||||
123.0
|
||||
<class 'float'>
|
||||
```
|
||||
__Пояснение:__ Разница только в количестве знаков после запятой в результате (в первом - до 1 десятичного знака, во-втором - до 0), но тип данных одинаковый
|
||||
|
||||
```py
|
||||
>>> c=round(123.456); c; type(c)
|
||||
123
|
||||
<class 'int'>
|
||||
```
|
||||
__Пояснение:__ Произошло округление до целого, и сохранился в "int"
|
||||
|
||||
## Пункт 2.2. Функция range
|
||||
__range__ - создание последовательности целых чисел с заданным шагом или, по умолчанию, с шагом 1.
|
||||
|
||||
```py
|
||||
>>> gg=range(76,123,9); gg #генерирует числа с 76 до 123 (пока не будет больше/равно) с шагом 9
|
||||
range(76, 123, 9)
|
||||
>>> type(gg)
|
||||
<class 'range'>
|
||||
>>> list(gg)
|
||||
[76, 85, 94, 103, 112, 121]
|
||||
>>> range(23) #Будет последовательность от 0 до 22 включительно с шагом 1
|
||||
range(0, 23)
|
||||
```
|
||||
|
||||
## Пункт 2.3. Функция zip
|
||||
__zip__ - создание общего объекта, элементами которого являются кортежи, составленные из элементов двух или более объектов-последовательностей
|
||||
|
||||
```py
|
||||
>>> qq=["Зеленкина", "Криви", "Цветкова", "Коломейцев"]
|
||||
>>> list(gg)
|
||||
[76, 85, 94, 103, 112, 121]
|
||||
>>> ff=zip(gg,qq); ff
|
||||
<zip object at 0x0000020E046D74C0>
|
||||
>>> type(ff)
|
||||
<class 'zip'>
|
||||
>>> tuple(ff)
|
||||
((76, 'Зеленкина'), (85, 'Криви'), (94, 'Цветкова'), (103, 'Коломейцев'))
|
||||
>>> ff[0]
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#175>", line 1, in <module>
|
||||
ff[0]
|
||||
TypeError: 'zip' object is not subscriptable
|
||||
>>> ff_list= list(zip(gg, qq)); ff_list[0]
|
||||
(76, 'Зеленкина')
|
||||
```
|
||||
|
||||
### Пункт 2.4. Функция eval
|
||||
__eval__ - вычисление значения выражения, корректно записанного на языке Python и представленного в виде символьной строки
|
||||
|
||||
```py
|
||||
>>> fff=float(input('коэффициент усиления=')); dan=eval('5*fff-156')
|
||||
коэффициент усиления=20
|
||||
>>> dan
|
||||
-56.0
|
||||
```
|
||||
|
||||
### Пункт 2.5. Функция exec
|
||||
|
||||
__exec__ - чтение и выполнение объекта-аргумента функции.
|
||||
|
||||
```py
|
||||
exec(input('введите инструкции:'))
|
||||
введите инструкции:perem=-123.456;gg=round(abs(perem)+98,3)
|
||||
gg
|
||||
221.456
|
||||
```
|
||||
|
||||
### Пункт 2.6. Самостоятельное применение функций
|
||||
|
||||
```py
|
||||
>>> abs(-100)
|
||||
100
|
||||
|
||||
>>> pow(5,2)
|
||||
25
|
||||
|
||||
>>> max(1,2,3,4,199, 13)
|
||||
199
|
||||
|
||||
>>> min(4,5,-10,-3,2)
|
||||
-10
|
||||
|
||||
>>> sum([4,8,3])
|
||||
15
|
||||
|
||||
>>> divmod(8,2)
|
||||
(4, 0)
|
||||
|
||||
>>> len('Привет, друг!')
|
||||
13
|
||||
|
||||
>>> n=[10,20,30,45]
|
||||
>>> map(str,n)
|
||||
<map object at 0x0000020E046CB100>
|
||||
>>> list(map(str,n))
|
||||
['10', '20', '30', '45']
|
||||
```
|
||||
## Пункт 3. Функции из стандартного модуля math
|
||||
|
||||
```py
|
||||
>>> import math
|
||||
>>> dir(math)
|
||||
['__doc__', '__loader__', '__name__', '__package__', '__spec__', 'acos', 'acosh', 'asin', 'asinh', 'atan', 'atan2', 'atanh', 'cbrt', 'ceil', 'comb', 'copysign', 'cos', 'cosh', 'degrees', 'dist', 'e', 'erf', 'erfc', 'exp', 'exp2', 'expm1', 'fabs', 'factorial', 'floor', 'fma', 'fmod', 'frexp', 'fsum', 'gamma', 'gcd', 'hypot', 'inf', 'isclose', 'isfinite', 'isinf', 'isnan', 'isqrt', 'lcm', 'ldexp', 'lgamma', 'log', 'log10', 'log1p', 'log2', 'modf', 'nan', 'nextafter', 'perm', 'pi', 'pow', 'prod', 'radians', 'remainder', 'sin', 'sinh', 'sqrt', 'sumprod', 'tan', 'tanh', 'tau', 'trunc', 'ulp']
|
||||
>>> help(math.factorial)
|
||||
Help on built-in function factorial in module math:
|
||||
|
||||
factorial(n, /)
|
||||
Find n!.
|
||||
|
||||
Raise a ValueError if x is negative or non-integral.
|
||||
|
||||
>>> math.factorial(5)
|
||||
120
|
||||
```
|
||||
Функции модуля: sin, acos, degrees, radians, exp, log, log10, sqrt, ceil, floor, pi:
|
||||
|
||||
```py
|
||||
>>> math.sin(45)
|
||||
0.8509035245341184
|
||||
>>> math.acos(0.8509035245341184)
|
||||
0.553093477052002
|
||||
>>> math.degrees(180)
|
||||
10313.240312354817
|
||||
>>> math.exp(1)
|
||||
2.718281828459045
|
||||
>>> math.log(10)
|
||||
2.302585092994046
|
||||
>>> math.log(4,2)
|
||||
2.0
|
||||
>>> math.log10(10)
|
||||
1.0
|
||||
>>> math.sqrt(16)
|
||||
4.0
|
||||
>>> math.ceil(10.8)
|
||||
11
|
||||
>>> math.ceil(-10.8)
|
||||
-10
|
||||
>>> math.floor(5.5)
|
||||
5
|
||||
>>> math.pi
|
||||
3.141592653589793
|
||||
```
|
||||
|
||||
## Пункт 4. Функции из модуля cmath
|
||||
Cовокупность функций для работы с комплексными числами.
|
||||
|
||||
```py
|
||||
>>> import cmath
|
||||
>>> dir(cmath)
|
||||
['__doc__', '__loader__', '__name__', '__package__', '__spec__', 'acos', 'acosh', 'asin', 'asinh', 'atan', 'atanh', 'cos', 'cosh', 'e', 'exp', 'inf', 'infj', 'isclose', 'isfinite', 'isinf', 'isnan', 'log', 'log10', 'nan', 'nanj', 'phase', 'pi', 'polar', 'rect', 'sin', 'sinh', 'sqrt', 'tan', 'tanh', 'tau']
|
||||
>>> cmath.sqrt(1.2-0.5j)
|
||||
(1.118033988749895-0.22360679774997896j)
|
||||
>>> cmath.phase(1-0.5j)
|
||||
-0.4636476090008061
|
||||
```
|
||||
|
||||
## Пункт 5. Стандартный модуль random
|
||||
Cовокупность функций для выполнения операций с псевдослучайными числами и выборками.
|
||||
|
||||
```py
|
||||
>>> import random
|
||||
>>> dir(random)
|
||||
['BPF', 'LOG4', 'NV_MAGICCONST', 'RECIP_BPF', 'Random', 'SG_MAGICCONST', 'SystemRandom', 'TWOPI', '_ONE', '_Sequence', '__all__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', '_accumulate', '_acos', '_bisect', '_ceil', '_cos', '_e', '_exp', '_fabs', '_floor', '_index', '_inst', '_isfinite', '_lgamma', '_log', '_log2', '_os', '_parse_args', '_pi', '_random', '_repeat', '_sha512', '_sin', '_sqrt', '_test', '_test_generator', '_urandom', 'betavariate', 'binomialvariate', 'choice', 'choices', 'expovariate', 'gammavariate', 'gauss', 'getrandbits', 'getstate', 'lognormvariate', 'main', 'normalvariate', 'paretovariate', 'randbytes', 'randint', 'random', 'randrange', 'sample', 'seed', 'setstate', 'shuffle', 'triangular', 'uniform', 'vonmisesvariate', 'weibullvariate']
|
||||
>>> help(random.seed)
|
||||
Help on method seed in module random:
|
||||
|
||||
seed(a=None, version=2) method of random.Random instance
|
||||
Initialize internal state from a seed.
|
||||
|
||||
The only supported seed types are None, int, float,
|
||||
str, bytes, and bytearray.
|
||||
|
||||
None or no argument seeds from current time or from an operating
|
||||
system specific randomness source if available.
|
||||
|
||||
If *a* is an int, all bits are used.
|
||||
|
||||
For version 2 (the default), all of the bits are used if *a* is a str,
|
||||
bytes, or bytearray. For version 1 (provided for reproducing random
|
||||
sequences from older versions of Python), the algorithm for str and
|
||||
bytes generates a narrower range of seeds.
|
||||
|
||||
>>> random.seed()
|
||||
|
||||
>>> random.seed(52)
|
||||
>>> random.random()
|
||||
0.9783548583709967
|
||||
>>> random.uniform(1, 5)
|
||||
1.2180906200418296
|
||||
>>> random.randint(1, 10)
|
||||
9
|
||||
>>> random.gauss(0, 2)
|
||||
-4.744196627534718
|
||||
>>> a=[15,6,8,10]
|
||||
>>> random.shuffle(a); a
|
||||
[8, 6, 15, 10]
|
||||
>>> random.sample(range(10), 2)
|
||||
[7, 0]
|
||||
>>> random.sample(range(10), 3)
|
||||
[0, 8, 6]
|
||||
>>> random.betavariate(3, 2)
|
||||
0.7782580563898469
|
||||
>>> random.gammavariate(3, 2)
|
||||
7.541042451721967
|
||||
```
|
||||
|
||||
Создайте список с 4 случайными значениями^
|
||||
|
||||
```py
|
||||
>>> r = [random.uniform(0, 20), random.gauss(13, 33),
|
||||
random.betavariate(5, 15), random.gammavariate(9, 2)]; r
|
||||
[9.981907966137051, 20.964805026393023, 0.13659209100569777, 10.30243231589178]
|
||||
```
|
||||
## Пункт 6. Функции из модуля time
|
||||
Работа с календарем и со временем.
|
||||
|
||||
```py
|
||||
>>> import time
|
||||
>>> dir(time)
|
||||
['_STRUCT_TM_ITEMS', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'altzone', 'asctime', 'ctime', 'daylight', 'get_clock_info', 'gmtime', 'localtime', 'mktime', 'monotonic', 'monotonic_ns', 'perf_counter', 'perf_counter_ns', 'process_time', 'process_time_ns', 'sleep', 'strftime', 'strptime', 'struct_time', 'thread_time', 'thread_time_ns', 'time', 'time_ns', 'timezone', 'tzname']
|
||||
|
||||
>>> c1=time.time(); c1
|
||||
1759666696.7083006
|
||||
>>> c2=time.time()-c1; c2
|
||||
15.599524736404419
|
||||
|
||||
>>> dat=time.gmtime(); dat
|
||||
time.struct_time(tm_year=2025, tm_mon=10, tm_mday=5, tm_hour=12, tm_min=20, tm_sec=10, tm_wday=6, tm_yday=278, tm_isdst=0)
|
||||
>>>dat.tm_mon
|
||||
10
|
||||
>>> dat.tm_year
|
||||
2025
|
||||
>>> dat.tm_mday
|
||||
5
|
||||
>>> dat.tm_hour
|
||||
12
|
||||
>>> dat.tm_min
|
||||
20
|
||||
>>> dat.tm_sec
|
||||
10
|
||||
>>> dat.tm_wday
|
||||
6
|
||||
>>> time.localtime()
|
||||
time.struct_time(tm_year=2025, tm_mon=10, tm_mday=5, tm_hour=15, tm_min=23, tm_sec=36, tm_wday=6, tm_yday=278, tm_isdst=0)
|
||||
>>> time.asctime()
|
||||
'Sun Oct 5 15:23:46 2025'
|
||||
>>> time.ctime()
|
||||
'Sun Oct 5 15:23:52 2025'
|
||||
>>> time.sleep(3)
|
||||
|
||||
>>> t=(2025, 10, 5, 15, 23, 36, 6, 278, 0)
|
||||
>>> obj= time.struct_time(t); obj
|
||||
time.struct_time(tm_year=2025, tm_mon=10, tm_mday=5, tm_hour=15, tm_min=23, tm_sec=36, tm_wday=6, tm_yday=278, tm_isdst=0)
|
||||
>>> s=time.mktime(obj);s
|
||||
1759667016.0
|
||||
>>> back=time.localtime(s);back
|
||||
time.struct_time(tm_year=2025, tm_mon=10, tm_mday=5, tm_hour=15, tm_min=23, tm_sec=36, tm_wday=6, tm_yday=278, tm_isdst=0)
|
||||
```
|
||||
|
||||
## Пункт 7. Графические функции
|
||||
|
||||
```py
|
||||
>>> import pylab
|
||||
>>> x=list(range(-3,55,4))
|
||||
>>> t=list(range(15))
|
||||
>>> pylab.plot(t,x)
|
||||
[<matplotlib.lines.Line2D object at 0x000001FA91846350>]
|
||||
>>> pylab.title('Первый график')
|
||||
Text(0.5, 1.0, 'Первый график')
|
||||
>>> pylab.xlabel('время')
|
||||
Text(0.5, 0, 'время')
|
||||
>>> pylab.ylabel('сигнал')
|
||||
Text(0, 0.5, 'сигнал')
|
||||
>>> pylab.show()
|
||||
```
|
||||
|
||||

|
||||
|
||||
```py
|
||||
>>> X1=[12,6,8,10,7]
|
||||
>>> X2=[5,7,9,11,13]
|
||||
>>> pylab.plot(X1)
|
||||
[<matplotlib.lines.Line2D object at 0x000001FA92FFED50>]
|
||||
>>> pylab.plot(X2)
|
||||
[<matplotlib.lines.Line2D object at 0x000001FA92FFEE90>]
|
||||
>>> pylab.show()
|
||||
```
|
||||
|
||||

|
||||
|
||||
#### Построение круговой диаграммы
|
||||
|
||||
```py
|
||||
>>> region=['Центр','Урал','Сибирь','Юг']
|
||||
>>> naselen=[65,12,23,17]
|
||||
>>> pylab.pie(naselen,labels=region)
|
||||
([<matplotlib.patches.Wedge object at 0x000001FA918016A0>, <matplotlib.patches.Wedge object at 0x000001FA9257CB90>, <matplotlib.patches.Wedge object at 0x000001FA9257CF50>, <matplotlib.patches.Wedge object at 0x000001FA9257D1D0>], [Text(-0.191013134139045, 1.0832885038559115, 'Центр'), Text(-0.861328292412156, -0.6841882582231001, 'Урал'), Text(0.04429273995539947, -1.0991078896938387, 'Сибирь'), Text(0.9873750693480946, -0.48486129194837324, 'Юг')])
|
||||
>>> pylab.show()
|
||||
```
|
||||

|
||||
|
||||
#### Гистограммы и столбиковые диаграммы
|
||||
Построим гистограмму:
|
||||
```py
|
||||
>>> import matplotlib.pyplot as plt
|
||||
>>> ocenki = [3, 4, 4, 5, 5, 5, 4, 3, 5, 4, 5, 5, 4, 3]
|
||||
>>> plt.hist(ocenki, color='orange', edgecolor='black')
|
||||
(array([3., 0., 0., 0., 0., 5., 0., 0., 0., 6.]), array([3. , 3.2, 3.4, 3.6, 3.8, 4. , 4.2, 4.4, 4.6, 4.8, 5. ]), <BarContainer object of 10 artists>)
|
||||
>>> plt.title('Распределение оценок в классе')
|
||||
Text(0.5, 1.0, 'Распределение оценок в классе')
|
||||
>>> plt.xlabel('Оценки')
|
||||
Text(0.5, 0, 'Оценки')
|
||||
>>> plt.ylabel('Количество учеников')
|
||||
Text(0, 0.5, 'Количество учеников')
|
||||
>>> plt.show()
|
||||
```
|
||||

|
||||
|
||||
Построим столбиковую диаграмму:
|
||||
```py
|
||||
>>> name = ['Пн', 'Вт', 'Ср', 'Чт', 'Пт']
|
||||
>>> number = [10, 25, 15, 30, 20]
|
||||
>>> plt.bar(name, number, color='skyblue')
|
||||
<BarContainer object of 5 artists>
|
||||
>>> plt.title('Моя диаграмма')
|
||||
Text(0.5, 1.0, 'Моя диаграмма')
|
||||
>>> plt.xlabel('Дни недели')
|
||||
Text(0.5, 0, 'Дни недели')
|
||||
>>> plt.ylabel('Значения')
|
||||
Text(0, 0.5, 'Значения')
|
||||
>>> plt.show()
|
||||
```
|
||||

|
||||
|
||||
## Пункт 8. Состав модуля statistics
|
||||
|
||||
```py
|
||||
>>> import statistics
|
||||
>>> g = [45, 50, 55, 60, 65, 70, 75, 80, 85, 200]
|
||||
>>> mean = statistics.mean(g); mean
|
||||
78.5
|
||||
>>> mode = statistics.mode(g); mode
|
||||
45
|
||||
>>>stdev = statistics.stdev(g); stdev
|
||||
44.60007473835292
|
||||
>>> variance = statistics.variance(g); variance
|
||||
1989.1666666666667
|
||||
>>> quantiles = statistics.quantiles(g, n=4); quantiles
|
||||
[53.75, 67.5, 81.25]
|
||||
>>> harmonic_mean = statistics.harmonic_mean(g); harmonic_mean
|
||||
66.96171069719155
|
||||
```
|
||||
|
||||
## Пунтк 9. Завершение сеанса IDLE
|
||||
@ -0,0 +1,56 @@
|
||||
# Общее контрольное задание
|
||||
|
||||
Зеленкина Катерина, А-02-23
|
||||
|
||||
## Задание
|
||||
|
||||
Реализовать, записать в текстовый файл и проанализировать результаты последовательности ин-струкций, выполняющих следующие действия:
|
||||
1. Напишите и исполните единое выражение, реализующее последовательное выполнение следу-ющих операций: вычисление фазы комплексного числа 0.2+0.8j, округление результата до двух знаков после запятой, умножение полученного значения на 20, получение кортежа из двух зна-чений: округленное вниз значение от деления результата на 3 и остатка от этого деления.
|
||||
2. Создайте объект класса struct_time с временными параметрами для текущего московского времени. Создайте строку с текущим часом и минутами.
|
||||
3. Создайте список с элементами – названиями дней недели. Сделайте случайную выборку из это-го списка с тремя днями недели.
|
||||
4. Напишите инструкцию случайного выбора числа из последовательности целых чисел от 14 до 32 с шагом 3.
|
||||
5. Сгенерируйте нормально распределенное число N с математическим ожиданием 15 и стандартным отклонением 4 и округлите его до целого значения. Создайте список с N элементами – случайно выбранными буквами латинского алфавита.
|
||||
6. Напишите инструкцию для определения временного интервала в минутах, прошедшего с момента предыдущего (из п.2) определения временных параметров.
|
||||
|
||||
## Решение
|
||||
|
||||
```py
|
||||
>>> import math
|
||||
>>> import cmath
|
||||
>>> import time
|
||||
>>> import random
|
||||
>>> import string
|
||||
>>> import statistics
|
||||
|
||||
>>> math.floor((round(cmath.phase(0.2+0.8j), 2) * 20) / 3), (round(cmath.phase(0.2+0.8j), 2) * 20) % 3
|
||||
(8, 2.6000000000000014)
|
||||
|
||||
>>> msc_time = time.localtime(time.time() + 3 * 3600); msc_time
|
||||
time.struct_time(tm_year=2025, tm_mon=10, tm_mday=6, tm_hour=4, tm_min=50, tm_sec=40, tm_wday=0, tm_yday=279, tm_isdst=0)
|
||||
>>> mytime = f"{msc_time.tm_hour:02d}:{msc_time.tm_min:02d}"; mytime
|
||||
'04:50'
|
||||
|
||||
>>> wd = ['Понедельник', 'Вторник', 'Среда', 'Четверг', 'Пятница', 'Суббота', 'Воскресенье']
|
||||
>>> p = random.sample(wd, 3); p
|
||||
['Суббота', 'Среда', 'Понедельник']
|
||||
|
||||
>>> k = list(range(14, 33, 3)); k
|
||||
[14, 17, 20, 23, 26, 29, 32]
|
||||
>>> rand = random.choice(k);rand
|
||||
14
|
||||
|
||||
>>> N = round(random.gauss(15, 4))
|
||||
>>> N=max(1,N); N
|
||||
22
|
||||
>>> rl = random.choices(string.ascii_uppercase, k=N); rl
|
||||
['J', 'Y', 'Z', 'Z', 'I', 'W', 'F', 'Y', 'B', 'H', 'G', 'N', 'B', 'F', 'B', 'D', 'P', 'Y', 'R', 'I', 'R', 'C']
|
||||
|
||||
>>> c = time.time();c
|
||||
1759705212.9430156
|
||||
>>> inter_sec = c - time.mktime(msc_time);inter_sec
|
||||
-10227.056984424591
|
||||
>>> inter_min = round(inter_sec / 60, 2); inter_min
|
||||
-170.45
|
||||
```
|
||||
|
||||
|
||||
|
После Ширина: | Высота: | Размер: 51 KiB |
|
После Ширина: | Высота: | Размер: 60 KiB |
|
После Ширина: | Высота: | Размер: 33 KiB |
|
После Ширина: | Высота: | Размер: 40 KiB |
|
После Ширина: | Высота: | Размер: 29 KiB |
Загрузка…
Ссылка в новой задаче