Архив метки: Python

Преобразование Bytearray в байты в Python

Python поддерживает множество различных типов объектов данных. Два из них — это объекты bytearray и bytes. Функция bytearray() возвращает объект массива байтов. Этот объект является изменяемым и поддерживает целые числа от 0 до 255. Функция bytes() возвращает байтовые объекты, не может быть изменена и поддерживает целые числа от 0 до 255. В этой статье будут описаны эти функции и объяснено, как можно преобразовать объекты байтового массива. в байтовые объекты.

 

Синтаксис метода bytearray()

bytearray ([ data_source [, encoding [, errors]]])

Три аргумента этого метода необязательны. Первый аргумент используется для инициализации списка байтов. Если первым аргументом является строка, то второй аргумент используется для кодирования. Наконец, третий аргумент используется для отображения ошибки в случае сбоя кодирования.

 

Синтаксис метода bytes()

bytes ([data_source [, encoding [, errors]]])

Все аргументы функции bytes() необязательны, как и метод bytearray(). Функции этих аргументов такие же, как и у упомянутого выше метода bytearray().

Способ преобразования ByteArray в байтах в Python будет показано ниже, используя несколько простых примеров для лучшего понимания этого процесса.

 

Пример 1: преобразование данных списка из байтового массива в байты

Когда функция bytearray() содержит только один аргумент, значением аргумента будет данные словаря или переменная. В следующем примере показано, как объект словаря может быть преобразован в объект байтового массива и как затем объект байтового массива может быть преобразован в байтовый объект. Затем первый цикл for используется для отображения значений таблицы трансляции кодов ASCII, а второй цикл for используется для отображения символов соответствующих кодов ASCII.

#!/usr/bin/env python3



# Определить список

listdata = [72, 69, 76, 76, 79]

# Распечатать содержимое списка

print(" n Значения словаря: n ", listdata)



# Инициализировать объект ByteArray , со списком

byteArrayObject = ByteArray(ListData)

# печать ByteArray, значение объекта

print(" n выходной метод ByteArray(): n" ,byteArrayObject)



# Преобразование объекта bytearray в объект 

byteObject = bytes(byteArrayObject)

# Печать значения объекта байтов

print(" n Вывод метода bytes(): n ", byteObject)



print(" n Значения байтов в формате ASCII ")

# Итерировать байтовый объект, используя цикл

for val in byteObject:

print(val,' ', end='')



print( " n Строковые значения байтов")

# Итерировать байтовый объект, используя цикл

for val in byteObject:

print(chr(val),' ', end='')

Выход

Следующий вывод появится после запуска скрипта. Здесь 72, 69, 76 и 79 — это код ASCII для символов «H», «E», «L» и «O» соответственно.

 

Пример 2: преобразование строковых данных из байтового массива в байты

В следующем примере показано преобразование объектов байтового массива в байтовые объекты строковых данных. В методе bytearray() этого скрипта используются два аргумента. Первый аргумент содержит строковое значение, а второй аргумент содержит строку кодировки. Здесь кодировка utf-8 используется для преобразования в объект байтового массива. Метод decode() используется в скрипте для преобразования байтовых объектов в строковые данные. Такая же кодировка используется во время преобразования.

#!/usr/bin/env python3



# Возьмите строковое значение

text = input("Введите любой текст: n")



# Инициализировать ByteArray объект строки и кодирование

byteArrObj = ByteArray(text, 'UTF-8')

print(" n Вывод метода bytesarray(): n ", byteArrObj)



# Конвертировать bytearray в байты

byteObj = bytes(byteArrObj)

print(" n Вывод метода bytes(): n", byteObj)

# Преобразовать байты значения в строку, используя emcoding

print(" n Строку значения байт»)

print(byteObj.Decode("UTF-8"))

 

Пример 3: преобразование целочисленных данных из байтового массива в байты

В предыдущих примерах показано преобразование массива байтов и байтов на основе словарных и строковых данных. В этом третьем примере показано преобразование массива байтов в байты на основе входных данных. Здесь входное значение преобразуется в целое число и передается в качестве аргумента через функцию bytearray(), а затем объект bytearray преобразуется в объект байтов. Нулевые значения, основанные на целочисленном числе, показаны как выходные данные объекта bytearray и bytes. Общее количество байтов подсчитывается с помощью метода len() в конце скрипта и будет равно целочисленному значению, переданному в качестве аргумента в метод bytearray().

#!/usr/bin/env python3



попробовать :

# Возьмем любое числовое значение

text = int(input("Введите любое число:"))



# Инициализировать ByteArray объект с номером

byteArrObj = bytearray(text)

print("n Вывод метода bytesarray(): n ", byteArrObj)



# Преобразование объекта

byteObj = bytes(byteArrObj)

print(" n Вывод метода bytes(): n ", byteObj)



# Распечатать размер объекта байтов

print(" n Длина объекта байтов: ", len(byteObj))

except ValueError:

print(" Введите любое число значение ")

Выход

После запуска сценария 6 используется в качестве входных данных для следующего вывода. Шесть нулевых значений отображаются как выходные данные массива байтов и байтов. Когда подсчитываются нулевые значения, отображается 6.

 

Пример 4: Создание массива байтов с помощью append() и преобразование в байты

В следующем примере показано, как объекты bytearray могут быть созданы с помощью метода append() и преобразованы в байты. Переменная arrVal объявлена здесь как объект bytearray. Затем шесть раз вызывается метод append() для добавления шести элементов в массив. Коды ASCII символов «P», «y», «t», «h», «o» и «n» равны 80, 121, 116, 104, 111 и 1120 соответственно. Они добавляются в объект bytearray. Этот объект массива позже преобразуется в объект байтов.

#!/usr/bin/env python3



# Создание ByteArray и добавить элемент, используя метод добавления()

arrVal = bytearray()

arrVal.append(80)

arrVal.append(121)

arrVal.append(116)

arrVal.append(104)

arrVal.append(111)

arrVal.append(110)



# Распечатать значения bytearray()

print(" n Вывод метода bytearray(): n", arrVal)



# Преобразование объекта bytearray в объект

byteObject = bytes(arrVal)



# Печать значения объекта байтов

print(" n Вывод метода bytes(): n ", byteObject)

 

Вывод

В этой статье показаны различные методы преобразования bytearray в байты после создания объектов bytearray. После прочтения этой статьи мы надеемся, что вы понимаете концепцию байтового массива и байтов, знаете, как преобразовать байтовый массив в байты, и сможете отображать вывод байтов в виде строки и символов.



2021-02-16T12:40:15
Python

Использование UUID в Python

В Python есть библиотека с именем UUID (универсальный уникальный идентификатор) для генерации случайного объекта длиной 128 бит. Эта библиотека генерирует уникальные идентификаторы на основе системного времени и сетевого адреса компьютера. Объект UUID неизменяем и содержит некоторые функции для создания различных уникальных идентификаторов. UUID используется для многих целей, таких как создание уникального случайного идентификатора, MAC-адреса на основе идентификатора, криптографических значений хеш-функции или случайных документов. Из этой статьи Вы узнаете, как создавать различные типы библиотек UUID, используя разные функции UUID.

 

Пример 1: Создание UUID на основе системного времени и MAC-адреса

В следующем примере показано использование функции  uuid1() модуля UUID для генерации различных значений UUID и читать и печатать различные значения свойств объекта UUID. Объект UID определяется путем вызова метода uuid1() для генерации уникального идентификатора на основе системного времени и MAC-адреса. Затем печатаются нормально сгенерированный идентификатор, соответствующее значение в байтах, целочисленное значение и шестнадцатеричное значение идентификатора. Затем в следующей части сценария печатаются свойства версии, полей, узла и времени идентификатора.

#!/usr/bin/env python3



# Импорт модуля uuid 

import uuid



# Создание случайного идентификатора с помощью uuid1()

UID = uuid.uuid1()



# Распечатать нормальный идентификатор

print("Нормальное значение:", UID)

# Распечатать байтовый идентификатор

print("Значение байта:", repr(UID.bytes))

# Распечатать целочисленный идентификатор

print("Целое число value:", UID.int)

# Распечатать шестнадцатеричный идентификатор

print(" Шестнадцатеричное значение:", UID.hex)



# Распечатать номер версии

print("Версия:", UID.version)

# Распечатать значения полей

print("Поля:", UID.fields)

# Распечатать значение MAC в шестнадцатеричном формате

print("Значение узла:", hex(UID.node))

# Распечатать значение времени

print(" Значение времени:", UID.time)

Выход

Вывод показывает, что значение идентификатора по умолчанию было сгенерировано в шестнадцатеричном формате путем разделения отдельных частей дефисом. Последняя часть значения идентификатора содержит MAC-адрес, который всегда будет одинаковым. Свойство узла объекта ID содержит MAC-адрес.

 

Пример 2: Создание значений SHA-1 и MD5 имени хоста с помощью uuid3() и uuid5()

Важное использование UUID — создание криптографических хеш-значений. Функции uuid3() и uuid5() модуля UUID используются для генерации MD5 и SHA-1 значения. В следующем сценарии переменная кортежа с именем hosts объявляется с тремя допустимыми URL-адресами. Значения кортежа повторяются с использованием цикла for. Затем значения MD5 и SHA-1 каждого URL-адреса вычисляются и печатаются на каждой итерации цикла.

#!/usr/bin/env python3

# Импорт модуля uuid

import uuid



# Определение кортежа из трех имен хостов 

hosts = ('www.andreyex.ru', 'www.google.com', 'zavod-gornica.ru')



# Итерировать значения кортежа, используя цикл

for hostname in hosts:

# Распечатать имя хоста

print("Hostname:", hostname)

# Используйте uuid5(), чтобы получить значение SHA-1

print('t Значение SHA-1:', uuid.uuid5(uuid.NAMESPACE_DNS, hostname))

# Используйте uuid3() для получения значения MD5

print('t Значение MD5:', uuid.Uuid3(uuid.NAMESPACE_DNS, hostname))

Пример 3: создание случайных чисел с помощью uuid4()

Если вы хотите , чтобы генерировать UUID случайным образом, то вы должны использовать функцию  uuid4() модуля UUID. Следующий скрипт сгенерирует пять UUID на основе случайных значений с помощью метода uuid4(). В то время как цикл используется здесь для вызова метода uuid4() пять раз и печатать случайно сгенерированные UUID значения.

#!/usr/bin/env python3



# Импорт модуля uuid

import uuid

# Инициализируем переменную

i = 1

# Повторяем цикл пять раз,

while(i<6):

# Сгенерируем случайное число

print("No-", i, ' ', uuid.uuid4())

# Увеличиваем значение на единицу

i = i + 1

 

Выход

Если вы запустите сценарий несколько раз, он будет генерировать разные UUID в разное время.

 

Пример 4: Создание отсортированного UUID из списка с помощью объекта UUID

В следующем сценарии показано, как преобразовать элементы списка в UUID и распечатать значения после сортировки. Здесь переменная list_ids объявляется с четырьмя элементами списка, где каждое значение элемента должно быть в допустимом формате UUID.Сначала печатаются исходные значения list_ids. Затем каждое значение элемента списка преобразуется в UUID с помощью цикла в блоке try. Если list_ids содержит какое-либо значение элемента, которое не соответствует формату UUID, будет сгенерировано исключение ValueError и будет напечатано сообщение об ошибке. Если во время преобразования ошибок не возникает, то преобразованные UUID сортируются с помощью метода sort(). Затем с помощью цикла for распечатываются отсортированные значения UUID.

#!/usr/bin/env python3

# Импорт модуля uuid

import uuid



# Создаем список идентификаторов допустимого формата

list_Ids = [

'a4f8dd97-c8be-345b-239e-8a68e6abf800',

'673a5eaa-56c6-aaaa-bc4567-4536cd,

'dcbbaa88-5bf1-11dd-ab48-990ab200d674',

'4567aabb-89ad-77ab-67ad-aaaccdd904ae'

]



# Распечатать значения списка с помощью цикла

print(' n Значения списка:')

for val in list_Ids:

print(val)



# Значения списка будут преобразованы в uuid и отсортированы

try:

  uuids = [ uuid.UUID(s) for s in list_Ids ]

  uuids.sort()

print(' n Значения отсортированных uuids:')

  for val in uuids:

    print (val)



except ValueError:

# Распечатать сообщение об ошибке, если какое-либо значение списка находится в недопустимом формате

print('Плохо сформированный шестнадцатеричный UUID')

 

Выход

В выводе появится все элементы в списке имеют правильный формат UUID. Таким образом, ValueError генерироваться не будет. Первая часть вывода напечатала исходные элементы списка, а вторая часть вывода напечатала отсортированные значения UUID.

 

Вывод

Вам может потребоваться сгенерировать UUID в Python для различных целей программирования. В этой статье показано, как сгенерировать различные UUID с помощью различных методов. После прочтения этой статьи и практики включенных примеров вы сможете создавать UUID в соответствии с вашими потребностями в программировании.



2021-02-15T13:52:07
Python

Создайте приложение PyQt на примере

PyQt — очень полезная библиотека Python, используемая для разработки графических приложений. Он использует среду Qt GUI Python, разработанную с использованием языка C++. Графический пользовательский интерфейс приложения может быть разработан путем импорта библиотеки PyQt в скрипт Python или с помощью модуля Qt Designer в PyQt. Если вы не хотите писать код для реализации графического интерфейса приложения, то лучше установить Qt Designer и создать с его помощью графический интерфейс пользователя. В этой статье шаг за шагом показан способ создания приложения PyQt на Python.

 

Создайте простое приложение PyQt для добавления:

В этом разделе статьи показаны шаги по реализации простого приложения PyQt для вычисления суммы двух чисел. Здесь числовые значения будут взяты у пользователя с использованием текстовых полей после выполнения скрипта, а затем после нажатия кнопки будет отображаться сумма значений. Здесь создано окно с необходимыми полями для построения дизайна приложения; Затем для вычисления суммы используется сценарий Python.

Шаги:

Шаг 1. Создайте объект приложения PyQt

Вам необходимо импортировать необходимые модули Python для разработки приложения PyQt из этой статьи. Для разработки этого приложения потребуются две метки, два текстовых поля и кнопка.

Модули QApplication, QMainWindow, QLabel, QTextEdit и QPushButton потребуются для разработки приложения.

Добавьте следующие строки в начало сценария, чтобы использовать эти модули.

# Импортировать необходимые модули

from PyQt5.QtWidgets import QApplication, QMainWindow, QLabel, QTextEdit, QPushButton

 

Добавьте следующие строки, чтобы создать объект приложения и запустить цикл обработки событий. Теперь после выполнения скрипта ничего не появится.

# Создать объект PyQt application

app = QApplication([])

# Запустить цикл событий для выполнения приложения

app.exec()

Шаг 2. Создайте класс и оконный объект

Создайте класс для добавления необходимых объектов на этом шаге для разработки окна приложения.

Добавьте следующие строки, чтобы создать класс с оконным объектом. Здесь задаются заголовок, размер и положение окна. Затем вызывается метод show() для отображения окна в качестве вывода.

class addition(QMainWindow):

def __init__(self):

# Вызвать родительский конструктор

super().__init__()

# Установить заголовок окна

self.setWindowTitle("Приложение добавления PyQt")

# Установить ширину и высоту окна

self.resize(350, 200)

# Сдвинуть положение окна

self.move(800, 400)

# Отображение окна

self.show()



 

Вы должны создать объект класса перед запуском цикла событий.

# Создание оконного объекта

window = add()

 

Следующее пустое окно появится после выполнения сценария.

 

Шаг 3: Добавьте необходимые виджеты в окно для добавления

Теперь добавьте необходимые объекты, необходимые для реализации приложения. На этом шаге создаются три объекта виджета QLabel, два объекта виджета QTextEdit и объект кнопки виджета QPushButton.Первые два объекта метки будут использоваться для предоставления текста помощи перед текстовыми полями. Объекты QTextEdit будут использоваться для получения от пользователя двух числовых значений. Будет создан объект QPushButton для вычисления суммы входных чисел с использованием функции обработчика событий, которая будет создана на следующем шаге. Последний объект метки будет использоваться для отображения суммы двух чисел. Здесь функция setGeometry () вызывается для каждого объекта, чтобы установить положение объекта в окне.

# Создать метку для первого номера

self.lbl1 = QLabel('Номер 1', self)

self.lbl1.setGeometry(80, 20, 80, 50)

# Создать текстовое поле для первого числа

self.textbox1 = QTextEdit(self)

self.textbox1.setGeometry(80, 60, 70, 30) 

# Создать метку для второго номера

self.lbl2 = QLabel('Номер 2', self)

self.lbl2.setGeometry(200, 20, 80, 50)

# Создать текстовое поле для второго числа

self.textbox2 = QTextEdit(self)

self.textbox2.setGeometry(200, 60, 70, 30)



# Создать кнопку для расчета суммы

self.submit = QPushButton('Вычислить сумму ', self)

self.submit.setGeometry(80, 100, 190, 30)

# Создать метку для отображения результата суммирования

self.lblResult = QLabel('', self)

self.lblResult.setGeometry(80, 130, 200, 50)



 

Следующий вывод появится после выполнения сценария. На этом шаге не создается функция-обработчик событий, которая используется для вычисления суммы чисел. Итак, если пользователь нажимает кнопку, ничего не произойдет.

 

Шаг 4. Создайте и вызовите функцию для обработки события нажатия кнопки.

Создайте метод с именем onClicked () со следующими строками внутри класса добавления для обработки события нажатия кнопки. Значения текстовых полей преобразуются в целые числа , используя Int () функцию и хранятся в num1 и num2 переменные. Далее, сумма num1 и num2 сохраняются в результате переменной. Значения num1, num2 и результирующих переменных преобразуются в значения строк с использованием ул () функцию, перед сохранением значения в выходной Переменная. Третий объект метки используется для отображения содержимого выходной переменной.

def onClicked(self):



num1 = int(self.textbox1.toPlainText())

num2 = int(self.textbox2.toPlainText())

result = num1 + num2

output = "<p style = 'color: blue'> Сумма из " + str(num1)+ " и " + str(num2)+"is" + str(result)+ '</p>'

self.lblResult.setText(output)



 

Добавьте следующие строки в класс после объекта кнопки для вызова метода onClicked() при нажатии кнопки.

# Вызов функции при нажатии кнопки

self.submit.clicked.connect(self.onClicked)

 

Если после выполнения сценария пользователь ввел 12 и 18 в текстовые поля и нажал кнопку «Вычислить сумму», под кнопкой появится следующий форматированный вывод.

 

Вывод :

Реализация очень простого приложения PyQt была объяснена в этой статье, начиная с базового, чтобы помочь новым пользователям Python. Надеюсь, что пользователь сможет спроектировать и создать простое приложение PyQt после правильного выполнения и понимания шагов этого руководства.



2021-02-14T12:05:04
Python

Как использовать флажок PyQt в Python?

Флажок используется для выбора нуля или более вариантов из многих вариантов с помощью графического пользовательского интерфейса. Форма с флажком может быть создана с помощью класса QCheckBox в скрипте Python или с помощью виджета QCheckBox в Qt Designer без написания какого-либо скрипта.

Когда форма с флажком создается с использованием класса QCheckBox, тогда вызывается функция stateChanged.connect(), чтобы применить действие, выполненное пользователем. Если пользователь установил какой-либо параметр флажка, тогда значение QtCore.Qt.checked будет True. С помощью класса QbuttonGroup можно создать несколько флажков с одним выбором, например Radio Button.

В этой статье показано, как создать форму с флажком, написав скрипт Python.

 

Необходимые методы QCheckBox

Класс QCheckBox имеет множество функций для выполнения различных типов задач с флажком. Некоторые наиболее часто используемые методы этого класса описаны ниже:










Название методаЦель
isChecked()Возвращает логическое значение. Когда пользователь щелкает, чтобы установить флажок, он возвращает True, в противном случае он возвращает False.
setChecked ()Он используется для изменения состояния флажка. Установлено значение True, чтобы флажок был установлен, а значение False — чтобы снять флажок.
text()Он используется для чтения метки флажка.
setText()Он используется для установки метки флажка.
isTriState()Возвращает логическое значение. Он используется для проверки тройного состояния, чтобы узнать, включен ли флажок.
setTriState()Он используется для включения третьего состояния флажка, который указывает нейтральное состояние.

 

Создайте форму с флажком, используя класс QCheckBox:

Использование флажка показано в этом разделе на различных типах примеров. Использование одного флажка, как показано в первом примере, и использование нескольких флажков показано во втором примере.

 

Пример 1: Создание единого флажка

В этом примере показан способ создания одного флажка с использованием класса QCheckBox и считывание входного значения флажка, предоставленного пользователем. Необходимые модули импортируются в начале скрипта. Метка используется в поле вышеупомянутого флажка для предоставления информации пользователю. Если пользователь установит флажок, чтобы проверить, скрипт напечатает: «Ух ты! Вы любите программировать», иначе сценарий напечатает: «О нет! Вы не любите программировать».

# Импортировать необходимые модули

import sys

from PyQt5 import QtCore, QtWidgets

from PyQt5.QtWidgets import QMainWindow, QCheckBox, QLabel, QVBoxLayout, QDesktopWidget

# Определите класс для создания формы с одним флажком

class SingleCheckbox(QMainWindow):

def __init__(self):

super().__init__()

# Создайте текст метки для пользователя

lb = QLabel(«Вам нравится программирование?», self)

lb.setGeometry(20, 20, 200, 20)

lb.move(20, 20)

# Создайте флажок с меткой

cb = QCheckBox(‘Да’, self)

cb.stateChanged.connect(self.Check_Answer)

cb.move(20, 50)

# Установить вертикальную планировку интервала QT

vbox = QVBoxLayout()

vbox.addWidget(lb)

vbox.addWidget(cb)

# Установите заголовок и размер окна

self.setWindowTitle(‘Form with Single Checkbox’)

self.setGeometry(60, 60, 300, 100)

# Отображение окна в центре экрана

win = self.frameGeometry()

pos = QDesktopWidget().availableGeometry().center()

win.moveCenter(pos)

self.move(win.topLeft())

self.show()

# Определите функцию для проверки ввода пользователя

def Check_Answer(self, state):

if state == QtCore.Qt.Checked:

print(«Ух ты! Вы любите программирование.»)

else:

print(«О нет! — Вы не любите программировать.»)

# Создайте объект приложения и выполните его

app = QtWidgets.QApplication(sys.argv)

form = SingleCheckbox()

app.exec()

 

Пример 2: Создание нескольких флажков

В этом примере показан метод создания нескольких флажков с использованием класса QCheckbox и чтения нескольких значений нескольких флажков. В окно добавляются две метки и три флажка. Первая метка добавляется в начале флажков для предоставления информации пользователю, а вторая метка добавляется в конец флажков для отображения значений выбранных флажков или флажков.

# Импортировать необходимые модули

import sys

from PyQt5.QtWidgets import (QWidget, QCheckBox, QApplication, QVBoxLayout, QLabel, QDesktopWidget)

# Определите класс для создания формы с несколькими флажками

class MultipleCheckbox(QWidget):

def __init__(self):

super().__init__()

# Установите текст метки для пользователя

lb = QLabel(«Выберите свою любимую еду(ы):», self)

lb.setGeometry(20, 20, 100, 20)

lb.move(20, 20)

# Создайте три флажка

cb1 = QCheckBox(‘Шоколадный торт’, self)

cb1.move(20, 70)

cb1.stateChanged.connect(lambda: self.Selected_Value(cb1))

cb2 = QCheckBox(‘Мороженое’, self)

cb2.move(20, 90)

cb2.stateChanged.connect(lambda: self.Selected_Value(cb2))

cb3 = QCheckBox(‘Макароны’, self)

cb3.move(20, 110)

cb3.stateChanged.connect(lambda: self.Selected_Value(cb3))

self.label = QLabel(‘Ничего не выбрано’)

self.label.move(20, 150)

# Установить вертикальную планировку интервала QT

vbox = QVBoxLayout()

vbox.addWidget(lb)

vbox.addWidget(cb1)

vbox.addWidget(cb2)

vbox.addWidget(cb3)

vbox.addWidget(self.label)

self.setLayout(vbox)

self.setWindowTitle(‘Форма с несколькими флажками’)

self.setGeometry(60, 60, 350, 200)

self.lblText = »

# Отображение окна в центре экрана

win = self.frameGeometry()

pos = QDesktopWidget().availableGeometry().center()

win.moveCenter(pos)

self.move(win.topLeft())

self.show()

# Определите функцию для чтения входных данных пользователя

def Selected_Value(self, btn):

if self.lblText != »:

str = self.lblText

strArray = str.split(‘ ,’)

self.lblText = »

for val in strArray:

if btn.text() != val:

if self.lblText == »:

self.lblText = val

else:

self.lblText += ‘ ,’ + val

if btn.isChecked() == True:

if self.lblText == »:

self.lblText = btn.text()

else:

self.lblText += ‘ ,’ + btn.text()

else:

if btn.isChecked() == True:

if self.lblText == »:

self.lblText = btn.text()

else:

self.lblText += ‘ ,’ + btn.text()

self.label.setText(‘Вы выбрали n’ + self.lblText)

# Создайте объект приложения и выполните его

app = QApplication(sys.argv)

ex = MultipleCheckbox()

sys.exit(app.exec_())

 

Значение по умолчанию для второй метки — «Ничего не выбрано», и значение метки будет изменено, когда какой-либо флажок установлен или снят пользователем.

 

Вывод

Способ определения одного или нескольких флажков и чтения значений выбранных флажков был объяснен в этом руководстве на двух простых примерах. Группы флажков могут быть определены для выбора определенного флажка из группы, которая здесь не показана.



2021-02-13T05:59:26
Python

Как использовать функцию NumPy unique() в Python

Библиотека NumPy используется в Python для создания одного или нескольких размерных массивов, и у нее есть много функций для работы с массивом. Функция unique() — одна из полезных функций этой библиотеки для определения уникальных значений массива и возврата отсортированных уникальных значений. Эта функция также может возвращать кортеж значений массива, массив ассоциативных индексов и количество раз, когда каждое уникальное значение появляется в основном массиве. В этом руководстве показаны различные варианты использования этой функции.

 

Синтаксис:

Синтаксис этой функции приведен ниже.

array numpy.unique(input_array, return_index, return_inverse, return_counts, axis)

Эта функция может принимать пять аргументов, назначение которых объясняется ниже.

  • input_array: это обязательный аргумент, который содержит входной массив, из которого выходной массив будет возвращен путем извлечения уникальных значений. Если массив не является одномерным массивом, то массив будет сглаженным.
  • return_index: это необязательный аргумент, который может принимать логическое значение. Если для этого аргумента установлено значение True, он вернет индексы входного массива.
  • return_inverse: это необязательный аргумент, который может принимать логическое значение. Если для этого аргумента установлено значение True, он вернет индексы выходного массива, который содержит уникальные значения.
  • return_counts: это необязательный аргумент, который может принимать логическое значение. Если для этого аргумента установлено значение True, он вернет количество раз, когда каждый элемент уникального массива появляется во входном массиве.
  • axis: это необязательный аргумент, который может принимать любое целочисленное значение или None. Если для этого аргумента не задано значение, входной массив будет сглажен.

Функция unique() может возвращать четыре типа массивов на основе значений аргументов.

 

Пример 1: Распечатать уникальные значения одномерного массива

В следующем примере показано использование функции unique() для создания массива с уникальными значениями одномерного массива. В качестве значения аргумента функции unique() используется одномерный массив из 9 элементов. Возвращенное значение этой функции напечатано позже.

# Импортировать библиотеку NumPy



import numpy as np



# Создать массив целого числа



np_array = np. unique ([55, 23, 40, 55, 35, 90, 23, 40, 80])



# Распечатать уникальные значения



print("Массив уникальных значений: n", np_array)

 

Выход :

Входной массив содержит 6 уникальных элементов, которые отображаются на выходе.

 

Пример 2: Распечатать уникальные значения и индексы на основе входного массива

В следующем примере показано, как можно получить уникальные значения и индексы двумерного массива с помощью функции unique(). В качестве входного массива используется двумерный массив из 2 строк и 6 столбцов. Для аргумента return_index установлено значение True, чтобы получить индексы входного массива на основе уникальных значений массива.

# Импортировать библиотеку NumPy



import numpy as np



# Создать двумерный массив



np_array = np. array([ [ 6, 4, 9, 6, 2, 9 ], [ 3, 7, 7, 6, 1, 3 ] ])



# Распечатать двумерный массив



print("Содержимое двумерного массива : n", np_array)



# Создайте уникальный массив и индексный массив уникальных значений



unique_array, index_array = np. unique(np_array, return_index = True)



# Распечатать значения уникального и индексного массивов



print("Содержимое уникального массива: n", unique_array)



print("Содержимое индексного массива: n", index_array)

 

Выход :

Входной массив содержит 7 уникальных значений. На выходе отображается массив из 7 уникальных значений и 7 индексов этих значений из входного массива.

Пример 3: Распечатать уникальные значения и индексы на основе выходного массива

В следующем примере показано, как уникальные значения одномерного массива и индексы основаны на уникальных значениях с помощью функции unique (). В сценарии в качестве входного массива используется одномерный массив из 9 элементов. Значение аргумента return_inverse установлено в True, что вернет другой массив индексов на основе уникального индекса массива. И уникальный массив, и индексный массив напечатаны позже.

# Импортировать библиотеку NumPy



import numpy as np



# Создать массив целочисленных значений



np_array = np. array([ 10, 60, 30, 10, 20, 40, 60, 10, 20 ])



print("Значения входного массива: n", np_array)



# Создайте уникальный массив и обратный массив



unique_array, inverse_array = np.unique(np_array, return_inverse=True)



# Распечатать значения уникального массива и обратного массива



print("Значения уникального массива: n", unique_array)



print("Значения обратного массива: n", inverse_array)

 

Выход :

На выходе был показан входной массив, уникальный массив и обратный массив. Входной массив содержит 5 уникальных значений. Это 10, 20, 30, 40 и 60. Входной массив содержит 10 в трех индексах, которые являются первым элементом уникального массива. Итак, 0 появился в обратном массиве трижды. Остальные значения обратного массива были размещены таким же образом.

 

Пример 4: Распечатайте уникальные значения и частоту каждого уникального значения

В следующем примере показано, как функция unique () может получить уникальные значения и частоту каждого уникального значения входного массива. Значение аргумента return_counts было установлено в True для получения массива значений частоты. Одномерный массив из 12 элементов был использован в функции unique () в качестве входного массива. Массив уникальных значений и значения частоты были напечатаны позже.

# Импортировать библиотеку NumPy



import numpy as np



# Создать массив целочисленных значений



np_array = np. array([70, 40, 90, 50, 20, 90, 50, 20, 80, 10, 40, 30])



print("Значения входного массива: n", np_array)



# Создать уникальный массив и подсчитать массив



unique_array,count_array = np.unique(np_array, return_counts = True)



# Распечатать значения уникального массива и обратного массива



print("Значения уникального массива: n", unique_array)



print("Значения массива count: n", count_array)

Выход :

Входной массив, уникальный массив и массив счетчиков были напечатаны в выходных данных.

 

Заключение

Подробное использование функций unique() было объяснено в этом руководстве с использованием нескольких примеров. Эта функция может возвращать значения различных массивов, показанных здесь, с использованием одномерных и двумерных массивов.



2021-02-11T10:14:44
Python

Работа с временным файлом в Python

Иногда нам нужно временно хранить данные в файле для временного выполнения какой-либо задачи. Например, ежемесячный отчет о продажах любой организации можно создать, сохранив данные о продажах во временном файле. Лучше сохранить данные во временном файле для создания отчета, чтобы предотвратить случайное изменение исходных данных. Временный файл также можно использовать для защиты конфиденциальных данных. Создание временного файла и выполнение таких задач легко выполняется в Python с помощью модуля tempfile . Этот модуль содержит множество функций для создания временных файлов и папок и легкого доступа к ним. В этой статье показано использование модуля tempfile в Python.

 

Создание временного файла без модуля tempfile

Задачу временного файла можно выполнить без использования модуля tempfile, создав простой файл. Для этого вы должны создать обычный файл, выполнить временные задачи и удалить файл после выполнения задач. В этом примере временный файл с именем temp.txt открывается в режиме записи, и во временный файл записывается текст. Модуль ‘ os ‘ используется здесь для чтения содержимого файла temp.txt и удаления файла после выполнения задачи.

# Импортировать модуль os

import os# Определить имя временного файла

filename = ‘temp.txt’

# Открыть файл в режиме чтения

fh = open(filename, ‘w’)

try:

# Распечатать сообщение перед записью

print(«Запись в файл >>> n»)

# Записываем строку в файл

fh.write(«Тестирование временного файла»)

# Наконец, закроем файл после записи

fh.close()

finally:

# Напечатайте сообщение перед чтением

print(«<<< Чтение из файла»)

# Запустить команду bash, чтобы прочитать файл

os.system(«cat temp.txt»)

# Распечатать новую строку

print(«n»)

# Удалить временный файл

os.remove(filename)

Создание временного файла с помощью метода TemporaryFile()

В этом примере для создания временного файла используется модуль tempfile. В этом модуле есть много методов работы с временным файлом. Метод TemporaryFile() используется здесь для создания временного файла. Временный файл открывается в сценарии как текстовый файл в режиме записи. По умолчанию временный файл будет создан в текущем месте. Две строки текста записываются во временный файл с помощью метода write(). Затем вызывается метод seek(), чтобы установить указатель файла в начало файла. Содержимое файла печатается в терминале с помощью метода read(). Метод close() модуля используется для закрытия файла и автоматического удаления файла.

# Импортировать модуль временного файла

import tempfile# Объявить объект для открытия временного файла для записи

tmp = tempfile.TemporaryFile(‘w + t’)

try:

# Распечатать сообщение перед записью

print(‘Запись во временный файл …’)

# Записать данные во временный файл

tmp.write(‘AndreyEx n’)

tmp.write(‘Содержимое временного файла’)

# Перейти к началу файла

tmp.seek(0)

# Прочитать содержимое временного файла

print(‘ Чтение временного файла: n {0} ‘.format(tmp.read()))

finally:

# Автоматическое удаление временного файла

tmp.close()

Создание временного файла с использованием метода NamedTemporaryFile ()

В предыдущем примере имя временного файла создается случайным образом. Но если вы хотите установить любое собственное имя для временного файла, вы должны использовать метод NamedTemporaryFile() для создания временного файла. В этом примере временный файл открывается в режиме записи с помощью метода NamedTemporaryFile(). Далее устанавливается имя файла temp.txt. Одна строка текста записывается в файл и считывается из файла, как в предыдущем примере. Ранее упоминалось, что временный файл удаляется автоматически при вызове метода close(). После удаления здесь используется модуль ‘os’, чтобы проверить, существует ли временный файл.

# Импортировать модуль временного файла

import tempfile# Импортировать модуль os

import os

# Объявить объект для открытия временного файла для записи

tmp = tempfile.NamedTemporaryFile(‘w + t’)

# Объявить имя временного файла

tmp.name = «temp.txt»

try:

# Распечатать сообщение перед записью

print(‘Записать данные во временный файл …’)

# Записать данные во временный файл

tmp.write(‘Это временное содержимое.’)

# Перейти к началу файла

tmp.seek(0)

# Прочитать содержимое временного файла

print(‘Прочитать содержимое временного файла: n {0}’ .format(tmp.read()))

finally:

# Удалить файл автоматически

tmp.close()

# Проверить, существует ли файл,

if (os.path.exists(tmp.name)) :

print(‘Файл существует’)

else:

print(‘Файл не существует’)

Создание временного файла с префиксом и суффиксом

Все временные файлы создаются в текущем месте для предыдущих примеров. Местоположение временного файла, а также префикс и суффикс для временного файла можно указать во время создания файла с помощью метода NamedTemporaryFile(). Согласно следующему сценарию, временное имя файла будет начинаться с «tm_» и заканчиваться на «_fl». Файл будет сохранен в папке «/tmp». После создания файла временное имя файла печатается с использованием свойства name . Затем модуль ‘ os’ проверяет, удален файл или нет.

# Импортировать модуль временного файла

import tempfile# Импортировать модуль os

import os

# Объявить объект для создания временного файла с суффиксом и префиксом

tmp = tempfile.NamedTemporaryFile(mode = ‘w + t’, prefix = ‘tm_’, suffix = ‘_fl’, dir = ‘/tmp’)

# Распечатать временное имя файла

print(tmp.name)

try:

# Распечатать сообщение перед записью

print(‘Записать данные во временный файл …’)

# Записать данные во временный файл

tmp.write(‘Это временное содержимое.’)

finally:

# Автоматически удалить файл

tmp.close()

if (os.path.exists(tmp.name) == False) :

print(‘Файл удален’)

Заключение:

Обычным требованием для любого языка программирования является создание временного файла для выполнения многих задач по запросу и работы с теми данными, которые не требуется хранить постоянно. В этой статье объясняются некоторые необходимые методы модуля tempfile, чтобы показать способы использования временного файла. Надеюсь, читатель сможет легко создавать и использовать временные файлы после прочтения этой статьи.



2021-01-28T09:15:56
Python