Código de Python - Lector, por cámara, de códigos "QR"

Imágen de perfil
Val: 712
Bronce
Ha aumentado 1 puesto en Python (en relación al último mes)
Gráfica de Python

Lector, por cámara, de códigos "QR"gráfica de visualizaciones


Python

Actualizado el 27 de Marzo del 2024 por Antonio (75 códigos) (Publicado el 22 de Abril del 2020)
42.259 visualizaciones desde el 22 de Abril del 2020
El programa tiene como objeto principal, la lectura, haciendo uso de la cámara web, de códigos QR. Para ello, simplemente pulsaremos el botón "INICIAR LECTURA POR CAMARA" (que desplegará el visor de la cámara) y colocaremos el código a leer, delante de la cámara. A su vez, también podremos leer códigos QR, en formato "png" y "jpg" almacenados en nuestra computadora (para lo que usaremos la opción "CARGAR ARCHIVO". Finalmente, también podremos leer, directamente, un código que se encuentre visible en pantalla (botón "DETECTAR EN PANTALLA").

qrcc
qrcm1

Requerimientos

Lenguaje: Python
Librerías: pyzbar, tkinter, opencv, PIL, numpy, os, pyautogui.

3.0
estrellaestrellaestrellaestrellaestrella(7)

Actualizado el 22 de Julio del 2021 (Publicado el 22 de Abril del 2020)gráfica de visualizaciones de la versión: 3.0
9.320 visualizaciones desde el 22 de Abril del 2020

3.1
estrellaestrellaestrellaestrellaestrella(1)

Actualizado el 7 de Noviembre del 2022 (Publicado el 26 de Julio del 2021)gráfica de visualizaciones de la versión: 3.1
19.957 visualizaciones desde el 26 de Julio del 2021

3.2
estrellaestrellaestrellaestrellaestrella(4)

Actualizado el 27 de Marzo del 2024 (Publicado el 12 de Diciembre del 2022)gráfica de visualizaciones de la versión: 3.2
12.983 visualizaciones desde el 12 de Diciembre del 2022
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

Esta versión incorpora la visualización del directorio de ejecución e incluye una función de copiado de la información (botón 'COPIAR').
qr1
qr2
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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import tkinter as tk
import tkinter.scrolledtext as scrolledtext
from tkinter import messagebox, filedialog
from pyzbar.pyzbar import decode, ZBarSymbol
import cv2
import pyperclip
import pyautogui
import numpy as np
import threading
from PIL import Image, ImageTk, ImageDraw, ImageGrab
import os
 
class App:
    def __init__(self,font_video=0):
        self.active_camera = False
        self.info = []
        self.codelist = []
        self.appName = 'QR Code Reader'
        self.ventana = tk.Tk()
        self.ventana.title(self.appName)
        self.ventana.resizable(height=tk.FALSE,width=tk.FALSE)##
        self.ventana['bg']='black'
        self.currentDir = tk.StringVar()
        self.currentDir.set(os.getcwd())
        self.font_video=font_video
        tk.Entry(self.ventana,textvariable=self.currentDir,width=107).pack(side=tk.TOP)
        tk.Label(self.ventana,text=self.appName,font=15,bg='blue',
                         fg='white').pack(side=tk.TOP,fill=tk.BOTH)
        bt_canvas = tk.Canvas(self.ventana)
        bt_canvas.pack(side=tk.BOTTOM)
        tk.Button(bt_canvas,text="GUARDAR",width=10,bg='light blue',command=self.guardar).pack(side=tk.LEFT)
        tk.Button(bt_canvas,text="COPIAR",width=10,bg='light blue',command=self.copy_info).pack(side=tk.LEFT)
 
        self.display=scrolledtext.ScrolledText(self.ventana,width=86,background='snow3'
                                        ,height=4,padx=10, pady=10,font=('Arial', 10))
        self.display.pack(side=tk.BOTTOM)
 
        self.canvas=tk.Canvas(self.ventana,bg='black',width=640,height=0)
        self.canvas.pack()
        tk.Button(self.ventana,text="CARGAR ARCHIVO",width=29,bg='goldenrod2',activebackground='red',command=self.abrir).pack(side=tk.LEFT)
        self.btnCamera=tk.Button(self.ventana,text="INICIAR LECTURA POR CAMARA",width=30,bg='goldenrod2',
                                activebackground='red',command=self.active_cam)
        self.btnCamera.pack(side=tk.LEFT)
        tk.Button(self.ventana,text="DETECTAR EN PANTALLA",width=29,bg='goldenrod2',activebackground='red',command=self.screen_shot).pack(side=tk.RIGHT)
 
        self.ventana.mainloop()
 
    def guardar(self):
        if len(self.display.get('1.0',tk.END))>1:
            documento = filedialog.asksaveasfilename(initialdir="/",
                        title="Guardar en",defaultextension='.txt')
            if documento != "":
                archivo_guardar = open(documento,"w",encoding="utf-8")
                linea=""
                for c in str(self.display.get('1.0',tk.END)):
                    linea=linea+c
                archivo_guardar.write(linea)
                archivo_guardar.close()
                messagebox.showinfo("GUARDADO","INFORMACIÓN GUARDADA EN \'{}\'".format(documento))
 
    def copy_info(self):
        try:
            if len(self.display.get('1.0',tk.END))>1:
                pyperclip.copy(self.display.get('1.0',tk.END))
                messagebox.showinfo("COPIADO","Copiado en el portapapeles.")
        except Exception as e:
            messagebox.showwarning("UNEXPECTED ERROR",str(e))
 
    def abrir(self):
        ruta = filedialog.askopenfilename(initialdir="/",title="SELECCIONAR ARCHIVO",
                    filetypes =(("png files","*.png") ,("jpg files","*.jpg")))
        if ruta != "":
            archivo = cv2.imread(ruta)
            self.info = decode(archivo)
            if self.info != []:
                self.display.delete('1.0',tk.END)
                for i in self.info:
                    self.display.insert(tk.END,(i[0].decode('utf-8'))+'\n')
            else:
                messagebox.showwarning("ARCHIVO NO VÁLIDO","NO SE DETECTÓ CÓDIGO QR.")
 
    def screen_shot(self):
        screenshot = ImageGrab.grab() # captura pantalla
        screenshot = np.array(screenshot) # arregle numpy
 
        self.info = decode(screenshot)
        if self.info != []:
            self.display.delete('1.0', tk.END)
            for i in self.info:
                self.display.insert(tk.END, (i[0].decode('utf-8')) + '\n')
        else:
            messagebox.showwarning("QR NO ENCONTRADO", "NO SE DETECTÓ CÓDIGO")
 
    def visor(self):
        ret, frame=self.get_frame()
        if ret:
            self.photo = ImageTk.PhotoImage(image=Image.fromarray(frame))
            self.canvas.create_image(0,0,image=self.photo,anchor=tk.NW)
            self.ventana.after(15,self.visor)
 
    def active_cam(self):
        if self.active_camera == False:
            self.active_camera = True
            self.VideoCaptura()
            self.visor()
        else:
            self.active_camera = False
            self.codelist = []
            self.btnCamera.configure(text="INICIAR LECTURA POR CAMARA")
            self.vid.release()
            self.canvas.delete('all')
            self.canvas.configure(height=0)
 
    def capta(self,frm):
        self.info = decode(frm)
        cv2.putText(frm, "Muestre el codigo delante de la camara para su lectura", (84, 37), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 255, 0), 2)
        if self.info != []:
            self.display.delete('1.0',tk.END)
            for code in self.info:
                if code not in self.codelist:
                    content = code[0].decode('utf-8')
                    self.codelist.append(content)
                    self.display.insert(tk.END,content+'\n')
                self.draw_rectangle(frm)
        else:
            if len(self.codelist)>0:
                self.display.delete('1.0',tk.END)
                for e in set(self.codelist):
                    self.display.insert(tk.END,e+'\n')
 
    def get_frame(self):
        if self.vid.isOpened():
            verif,frame=self.vid.read()
            if verif:
                self.btnCamera.configure(text="CERRAR CAMARA")
                self.capta(frame)
                return(verif,cv2.cvtColor(frame, cv2.COLOR_BGR2RGB))
            else:
                messagebox.showwarning("CAMARA NO DISPONIBLE","""La cámara está siendo utilizada por otra aplicación.
                Cierrela e intentelo de nuevo.""")
                self.active_cam()
                return(verif,None)
        else:
            verif=False
            return(verif,None)
 
    def draw_rectangle(self,frm):
        codes = decode(frm)
        for code in codes:
            data = code.data.decode('ascii')
            x, y, w, h = code.rect.left, code.rect.top, \
                        code.rect.width, code.rect.height
            cv2.rectangle(frm, (x,y),(x+w, y+h),(255, 0, 0), 6)
            cv2.putText(frm, code.type, (x - 10, y - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 50, 255), 2)
 
    def VideoCaptura(self):
        self.vid = cv2.VideoCapture(self.font_video)
        if self.vid.isOpened():
            self.width=self.vid.get(cv2.CAP_PROP_FRAME_WIDTH)
            self.height=self.vid.get(cv2.CAP_PROP_FRAME_HEIGHT)
            self.canvas.configure(width=self.width,height=self.height)
        else:
            messagebox.showwarning("CAMARA NO DISPONIBLE","El dispositivo está desactivado o no disponible")
            self.display.delete('1.0',tk.END)
            self.active_camera = False
 
    def __del__(self):
        if self.active_camera == True:
            self.vid.release()
 
if __name__=="__main__":
    App()



Comentarios sobre la versión: 3.2 (4)

Calvin
5 de Enero del 2023
estrellaestrellaestrellaestrellaestrella
muchas gracias Antonio por el aporte! Es justo lo que estaba necesitando :). Intenté generar un ejecutable con pyinstaller --onefile y al correr el exe tira error de dll ¿puedes darme alguna recomendación? Gracias
Responder
R
8 de Mayo del 2023
estrellaestrellaestrellaestrellaestrella
import numpy as np
import matplotlib.pyplot as plt

# Definir los valores de x en grados
x_grados = np.arange(0, 361, 1)

# Convertir los valores de x a radianes
x_radianes = np.radians(x_grados)

# Definir la función F(x) = 5e^(nx)
n = 1
F = 5 * np.exp(n * x_radianes * 1j)

# Crear la figura y los ejes
fig, ax = plt.subplots()

# Configurar los límites de los ejes
ax.set_xlim([0, 360])
ax.set_ylim([-5.5, 5.5])

# Configurar las etiquetas de los ejes
ax.set_xlabel('Ángulo (grados)')
ax.set_ylabel('F(x)')

# Crear la gráfica
ax.plot(x_grados, F.real)

# Mostrar la gráfica
plt.show()
Responder
25 de Septiembre del 2023
estrellaestrellaestrellaestrellaestrella
Python 3.11.5 (tags/v3.11.5:cce6ba9, Aug 24 2023, 14:38:34) [MSC v.1936 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> # Chiedi all'utente di inserire l'importo della spesa senza sconti
>>> importo_senza_sconti = float(input("Inserisci l'importo della spesa senza sconti: "))
Inserisci l'importo della spesa senza sconti:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: could not convert string to float: ''
>>> # Inizializza l'importo dello sconto a 0
>>> importo_sconto = 0
>>>
>>> # Applica lo sconto del 5% se l'importo è inferiore o uguale a 50 €
>>> if importo_senza_sconti <= 50:
... importo_sconto = importo_senza_sconti * 0.05
... # Applica lo sconto del 10% se l'importo è inferiore o uguale a 100 €
... elif importo_senza_sconti <= 100:
... importo_sconto = importo_senza_sconti * 0.10
... # Applica lo sconto del 15% se l'importo supera i 100 €
... else:
... importo_sconto = importo_senza_sconti * 0.15
...
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'importo_senza_sconti' is not defined
>>> # Calcola l'importo della spesa con lo sconto
>>> importo_con_sconto = importo_senza_sconti - importo_sconto
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'importo_senza_sconti' is not defined
>>>
>>> # Visualizza l'importo della spesa scontato
>>> print("L'importo della spesa scontato è:", importo_con_sconto)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'importo_con_sconto' is not defined. Did you mean: 'importo_sconto'?
>>>
Responder
25 de Septiembre del 2023
estrellaestrellaestrellaestrellaestrella
Python 3.11.5 (tags/v3.11.5:cce6ba9, Aug 24 2023, 14:38:34) [MSC v.1936 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> # Chiedi all'utente di inserire l'importo della spesa senza sconti
>>> importo_senza_sconti = float(input("Inserisci l'importo della spesa senza sconti: "))
Inserisci l'importo della spesa senza sconti:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: could not convert string to float: ''
>>> # Inizializza l'importo dello sconto a 0
>>> importo_sconto = 0
>>>
>>> # Applica lo sconto del 5% se l'importo è inferiore o uguale a 50 €
>>> if importo_senza_sconti <= 50:
... importo_sconto = importo_senza_sconti * 0.05
... # Applica lo sconto del 10% se l'importo è inferiore o uguale a 100 €
... elif importo_senza_sconti <= 100:
... importo_sconto = importo_senza_sconti * 0.10
... # Applica lo sconto del 15% se l'importo supera i 100 €
... else:
... importo_sconto = importo_senza_sconti * 0.15
...
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'importo_senza_sconti' is not defined
>>> # Calcola l'importo della spesa con lo sconto
>>> importo_con_sconto = importo_senza_sconti - importo_sconto
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'importo_senza_sconti' is not defined
>>>
>>> # Visualizza l'importo della spesa scontato
>>> print("L'importo della spesa scontato è:", importo_con_sconto)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'importo_con_sconto' is not defined. Did you mean: 'importo_sconto'?
>>>
Responder

Comentar la versión: 3.2

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

http://lwp-l.com/s6145