Skip to main content

Tkinter Buttons Created in a for loops but can't reference data

I have a tkinter project i'm working on. The end goal is to have a Window appear that has all of the data in a json file appear as individual objects (either a button or next to a button) that can then be clicked to have the data altered and saved back to the json file as well as an option to add new levels.

What makes this complicated is that because I'm making it "future proof", i have to create the buttons in a loop, so their names are not defined for me to reference later. I've tried using cget(), passing them through a validation in tkinter, v.focus_get(), and none of them come up correct. For a second i thought that .grid() being on the same line might make me reference the grid object, while not wrong, changing that did not fix the issue. Using cget() gave me "." as whatever information i try to pull.

I'm not married to my formatting, it can be a pop up window, through text boxes, i just don't want to put it all in a listbox with all of the information where someone could then mess up the json formatting I will simplify the data in the json file and code below.

{
    "fabrication_cost": 17,
    "mark_up": 0.7,
    "stone_levels": {
        "granite1": {
            "Name": "Granite Level 1",
            "Colors": [
                "Azul Platino",
                "Blanco Tulum",
                "Caledonia",
                "Luna Pearl"
            ],
            "Price": 7.5
        },
        "granite2": {
            "Name": "Granite Level 2",
            "Colors": [
                "Fantasy Brown",
                "Gray Mist",
                "Santa Cecilia",
                "New Venetian Gold"
            ],
            "Price": 10
        },
        "granite3": {
            "Name": "Granite Level 3",
            "Colors": [
                "Nero Mist Honed",
                "Salinas White",
                "Steel Grey Polished",
                "Steel Grey Brushed"
            ],
            "Price": 12
        },
        "quartz1": {
            "Name": "Quartz Level 1",
            "Colors": [
                "Frost White",
                "Iced White",
                "Manhattan Gray",
                "Peppercorn White"
            ],
            "Price": 17
        },
        "quartz2": {
            "Name": "Quartz Level 2",
            "Colors": [
                "Carrara Grigio",
                "Carrara Mist",
                "Fossil Gray",
                "Midnight Majesty"
            ],
            "Price": 22.5
        },
        "quartz3": {
            "Name": "Quartz Level 3",
            "Colors": [
                "Babylon Gray",
                "Calacatta Classique",
                "Calacatta Vicenza",
                "Gray Lagoon"
            ],
            "Price": 25.5
        }
    },
    "edge_pricing": {
        "Roundover/Bevel": 8,
        "Half Bullnose": 10,
        "Full Bullnose": 15,
        "Ogee": 30,
        "Mitered": 50
    },
    "add_ons": {
        "trip_Charge": 250,
        "raw_Cutout": 50,
        "radii": 50,
        "arcs": 100,
        "splay": 100,
        "waterfall": 650,
        "farm_sink_cutout": 100,
        "undermount_Sink_Install": 100,
        "standard_18ga_Sink": 110,
        "upgrade_18ga_Sink": 240,
        "porcelain_Vanity_Sink": 45,
        "customer_Sink": 100
    }
}
import json
import tkinter as tk


class App(tk.Tk):
    def __init__(self):
        super().__init__()

        #load data from json file
        with open("pricing_data.json","r") as pricing_data_json:
            pricing_data = json.load(pricing_data_json)
        self.stone_levels = pricing_data['stone_levels']

        #create main frame
        self.main_frame = tk.Frame()
        self.main_frame.grid(row=0,column=0)

        self.create_widgets()

    def create_widgets(self):
        r=0
        for granite_level in self.stone_levels:

            lvl_name = self.stone_levels[granite_level]['Name']
            
            lvl_colors = self.stone_levels[granite_level]['Colors']

            tk.Button(master=self.main_frame, text=lvl_name).grid(row=r, column=0, sticky='news')
            tk.Button(master=self.main_frame, text=lvl_colors).grid(row=r+1, column=0, sticky='news')
            tk.Button(master=self.main_frame,text='Add New Level').grid(row=r+2, column=0)
            r+=3

app= App()
app.mainloop()


source https://stackoverflow.com/questions/74855937/tkinter-buttons-created-in-a-for-loops-but-cant-reference-data

Comments

Popular posts from this blog

Prop `className` did not match in next js app

I have written a sample code ( Github Link here ). this is a simple next js app, but giving me error when I refresh the page. This seems to be the common problem and I tried the fix provided in the internet but does not seem to fix my issue. The error is Warning: Prop className did not match. Server: "MuiBox-root MuiBox-root-1" Client: "MuiBox-root MuiBox-root-2". Did changes for _document.js, modified _app.js as mentioned in official website and solutions in stackoverflow. but nothing seems to work. Could someone take a look and help me whats wrong with the code? Via Active questions tagged javascript - Stack Overflow https://ift.tt/2FdjaAW

How to show number of registered users in Laravel based on usertype?

i'm trying to display data from the database in the admin dashboard i used this: <?php use Illuminate\Support\Facades\DB; $users = DB::table('users')->count(); echo $users; ?> and i have successfully get the correct data from the database but what if i want to display a specific data for example in this user table there is "usertype" that specify if the user is normal user or admin i want to user the same code above but to display a specific usertype i tried this: <?php use Illuminate\Support\Facades\DB; $users = DB::table('users')->count()->WHERE usertype =admin; echo $users; ?> but it didn't work, what am i doing wrong? source https://stackoverflow.com/questions/68199726/how-to-show-number-of-registered-users-in-laravel-based-on-usertype

Why is my reports service not connecting?

I am trying to pull some data from a Postgres database using Node.js and node-postures but I can't figure out why my service isn't connecting. my routes/index.js file: const express = require('express'); const router = express.Router(); const ordersCountController = require('../controllers/ordersCountController'); const ordersController = require('../controllers/ordersController'); const weeklyReportsController = require('../controllers/weeklyReportsController'); router.get('/orders_count', ordersCountController); router.get('/orders', ordersController); router.get('/weekly_reports', weeklyReportsController); module.exports = router; My controllers/weeklyReportsController.js file: const weeklyReportsService = require('../services/weeklyReportsService'); const weeklyReportsController = async (req, res) => { try { const data = await weeklyReportsService; res.json({data}) console