Skip to main content

why is creating multiple databases when I interact with socket.server?

  • I've created socket server in one .py file
  • I've created socket client into an another .py file
  • I've created a demo database into an another .py file

I want that client verify a social number from database thru server and now the party begins.. 1st issue: When I introduce another social number to be verified if exists, the previous one appears and when I introduce another social number, the social number that I've asked for to be verified before appears double times :-) 2nd issue: Now I have the same database twice in two different folders. It's driving me crazy :-) Please give me a hint what I'm doing wrong

Here are my sheets:

database

from sqlalchemy import create_engine, Column, Integer, String, select
from sqlalchemy.orm import sessionmaker, declarative_base
class Personas():
    personas = create_engine('sqlite:///personas.db')
    Session = sessionmaker(bind=personas)
    sessionDB = Session()
    Base = declarative_base()

class TablePersona(Personas.Base):
    __tablename__ = 'Personas'
    id = Column('id', Integer, primary_key=True)
    name = Column('name', String)
    first_name = Column('firstName', String)
    dni = Column('DNI', Integer)

    def __init__(self, first_name, name, dni):
        self.name = name
        self.first_name = first_name
        self.dni = dni`

    `def __repr__(self):
        return f'{self.apellido} {self.nombre} tiene DNI={self.dni}'


def vizualizar_por_dni(param):
    dni = Personas.sessionDB.query(TablePersona).filter(TablePersona.dni == param).all()
    res = dni
    if len(res) > 0:
        for i in res:
            return i
    else:
        return f'Persona con DNI: {param} no existe!'


def insertar(nombre, apellido, dni):
    persona = TablePersona(nombre, apellido, dni)
    Personas.sessionDB.add(persona)
    Personas.sessionDB.commit()


def main():
    Personas.Base.metadata.create_all(Personas.personas)

socket.server .py

import socket

from personas import vizualizar_por_dni


def server():
    # he creado server con "with" loop para olvider de ese .close()
    with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
        server_address = (socket.gethostbyname(socket.gethostname()), 1234)
        s.bind(server_address)
        s.listen(10)
        print("Server address is: ip: {} port: {}".format(*server_address))
        connection, address = s.accept()
        with connection:
            print(f"Cliente {address} connected")
            while True:
                data = connection.recv(10000000)
                if not data:
                    print("No he recibido datas!")
                    break
                datas_recibido = data.decode()
                message_to_send = f'{vizualizar_por_dni(datas_recibido)}'.encode()
                if len(message_to_send) > 0:
                    connection.sendall(message_to_send)
                else:
                    message_reply = b'Ningun persona con ese DNI!'
                    connection.sendall(message_reply)

socket.client .py

import socket


def client():
    with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
        s.connect((socket.gethostname(), 1234))
        while True:
            usuario = input("Introduce el DNI: \n")
            message = usuario.encode()
            s.sendall(message)
            if s.sendall(message):
                print("the client had sent the message")
            data = s.recv(10000000)
            received_message = data.decode()
            if len(received_message) > 0:
                print(received_message)
            else:
                print("Nothing received")
            continuar = input('Quieres que continuar? S or N')
            if continuar.capitalize() == 'S':
                continue
            elif continuar.capitalize() == 'N':
                break
        print("Connection closed")

Sorry for the spanglish mix over there, i'm still learning python



source https://stackoverflow.com/questions/76124674/why-is-creating-multiple-databases-when-i-interact-with-socket-server

Comments

Popular posts from this blog

ValueError: X has 10 features, but LinearRegression is expecting 1 features as input

So, I am trying to predict the model but its throwing error like it has 10 features but it expacts only 1. So I am confused can anyone help me with it? more importantly its not working for me when my friend runs it. It works perfectly fine dose anyone know the reason about it? cv = KFold(n_splits = 10) all_loss = [] for i in range(9): # 1st for loop over polynomial orders poly_order = i X_train = make_polynomial(x, poly_order) loss_at_order = [] # initiate a set to collect loss for CV for train_index, test_index in cv.split(X_train): print('TRAIN:', train_index, 'TEST:', test_index) X_train_cv, X_test_cv = X_train[train_index], X_test[test_index] t_train_cv, t_test_cv = t[train_index], t[test_index] reg.fit(X_train_cv, t_train_cv) loss_at_order.append(np.mean((t_test_cv - reg.predict(X_test_cv))**2)) # collect loss at fold all_loss.append(np.mean(loss_at_order)) # collect loss at order plt.plot(np.log(al...

Sorting large arrays of big numeric stings

I was solving bigSorting() problem from hackerrank: Consider an array of numeric strings where each string is a positive number with anywhere from to digits. Sort the array's elements in non-decreasing, or ascending order of their integer values and return the sorted array. I know it works as follows: def bigSorting(unsorted): return sorted(unsorted, key=int) But I didnt guess this approach earlier. Initially I tried below: def bigSorting(unsorted): int_unsorted = [int(i) for i in unsorted] int_sorted = sorted(int_unsorted) return [str(i) for i in int_sorted] However, for some of the test cases, it was showing time limit exceeded. Why is it so? PS: I dont know exactly what those test cases were as hacker rank does not reveal all test cases. source https://stackoverflow.com/questions/73007397/sorting-large-arrays-of-big-numeric-stings

How to load Javascript with imported modules?

I am trying to import modules from tensorflowjs, and below is my code. test.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title </head> <body> <script src="https://cdn.jsdelivr.net/npm/@tensorflow/tfjs@2.0.0/dist/tf.min.js"></script> <script type="module" src="./test.js"></script> </body> </html> test.js import * as tf from "./node_modules/@tensorflow/tfjs"; import {loadGraphModel} from "./node_modules/@tensorflow/tfjs-converter"; const MODEL_URL = './model.json'; const model = await loadGraphModel(MODEL_URL); const cat = document.getElementById('cat'); model.execute(tf.browser.fromPixels(cat)); Besides, I run the server using python -m http.server in my command prompt(Windows 10), and this is the error prompt in the console log of my browser: Failed to loa...