Skip to main content

NameError: name 'run_gui_update_in_thread' is not defined

Can someone tell me whats wrong with my code, whenever i delete something, a new error pops up the code is a dumpster fire to be honest. tkinter is having errors with simple task, most of the pip installs aren't required, and the code doesn't connect to the plc. The task the code is supposed to connect to the plc and give the status of the tag into microsoft SQL server management Studio. Would very much appreciate any ideas or help. Thanks.

import threading
import tkinter as tk
from tkinter import ttk
import datetime
import time
import logging
import pyodbc
from pylogix import PLC
import matplotlib.pyplot as plt
from matplotlib.dates import DateFormatter
import tkinter as tk
import threading
# ... other necessary imports ...

# Define global variables
root = None
tree = None
plc_thread = None
running = False  # Flag to control the PLC reading thread

def read_and_write_plc_data():
    """Read data from PLC and write to database."""
    global running
    plc = PLC()
    plc.IPAddress = PLC_IP
    while running:
        try:
            data = plc.Read(TAGS_TO_READ)
            write_to_database(data)
        except Exception as e:
            logging.error(f"PLC read/write error: {e}")
        time.sleep(1)  # Adjust the frequency as needed

def start_plc_process():
    """Start the PLC reading and writing process."""
    global plc_thread, running
    if not running:
        running = True
        plc_thread = threading.Thread(target=read_and_write_plc_data, daemon=True)
        plc_thread.start()

def stop_plc_process():
    """Stop the PLC reading and writing process."""
    global running
    running = False

def setup_gui():
    """Set up the GUI layout and components."""
    global root, tree
    root = tk.Tk()
    root.title("PLC Data Viewer")

    # Start button
    start_button = tk.Button(root, text="Start PLC Process", command=start_plc_process)
    start_button.pack()

    # Stop button
    stop_button = tk.Button(root, text="Stop PLC Process", command=stop_plc_process)
    stop_button.pack()

    # Setup other GUI components (treeview, labels, etc.)
    # ...

    return root

# ... The rest of your existing code ...

if __name__ == "__main__":
    root = setup_gui()

# Initialize logging
logging.basicConfig(filename="plc_data.log", level=logging.INFO)

# Database and PLC connection settings
DRIVER = 'driver'
DATABASE = 'AI'
SERVER = 'info...'
PLC_IP = "1111"
TAGS_TO_READ = ['tag']

def create_connection():
    """Create a database connection."""
    conn_str = f'DRIVER=};SERVER={SERVER};DATABASE={DATABASE}'
    return pyodbc.connect(conn_str, timeout=10)

def read_from_plc(plc):
    """Read data from the PLC."""
    # Implement the logic to read from the PLC
    # Example: return plc.Read('Some_Tag')
    pass

def write_to_database(data):
    """Write data to the database."""
    try:
        with create_connection() as conn:
            cursor = conn.cursor()
            # Implement the SQL INSERT logic
            # Example: cursor.execute("INSERT INTO table_name (column1, column2) VALUES (?, ?)", data1, data2)
            conn.commit()
    except Exception as e:
        logging.error(f"Database write failed: {e}")

def fetch_from_database():
    """Fetch data from the database."""
    try:
        with create_connection() as conn:
            cursor = conn.cursor()
            cursor.execute("SELECT * FROM your_table")  # Adjust your SQL query
            return cursor.fetchall()
    except Exception as e:
        logging.error(f"Database read failed: {e}")
        return []

def setup_gui():
    """Set up the GUI."""
    root = tk.Tk()
    root.title("PLC Data Viewer")

    # Set up GUI elements like buttons, labels, treeview, etc.
    # ...

    return root

def update_gui(root, tree):
    """Update the GUI with new data."""
    data = fetch_from_database()
    # Update your treeview or other GUI elements with 'data'
    # ...
    root.after(1000, lambda: update_gui(root, tree))  # Update GUI every 1000 ms

def plc_data_thread():
    """Thread to read data from PLC and write to database."""
    plc = PLC()
    plc.IPAddress = PLC_IP
    while True:
        data = read_from_plc(plc)
        write_to_database(data)
        time.sleep(1)  # Read data every 1 second

if __name__ == "__main__":
    root = setup_gui()
    tree = None  # Replace with actual treeview initialization
    update_gui(root, tree)

    # Start PLC data thread
    threading.Thread(target=plc_data_thread, daemon=True).start()

    root.mainloop()


source https://stackoverflow.com/questions/77816464/nameerror-name-run-gui-update-in-thread-is-not-defined

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...