Tkinter - Treeview Edit Cells Directly

Поделиться
HTML-код
  • Опубликовано: 21 июл 2024
  • I'll show you how to edit individual cells in the Treeview widget.
    You will be able to double-click a cell and edit the value directly.
    This involves placing an entry widget over top of a Treeview cell at the right time, which then allows the user to edit the text.
    The treeview widget provides the methods we need to make this happen.
    A reference site which lists some of the methods we will be using in the Treeview widget:
    tkdocs.com/shipman/ttk-Treevie...
    0:00 Intro
    0:57 Demo app
    1:18 Starter code
    2:00 Create a treeview class
    4:35 Create columns
    5:19 Add text to heading
    6:42 Insert rows
    9:28 Bind to double-click
    12:03 Identify region double-clicked
    16:43 Identify which item was double-clicked
    20:16 Difference between text and values
    21:57 Get selected text or values
    23:50 Get cell text
    27:04 Get cell bounding box
    30:43 Create entry widget
    35:02 Demo app with entry widget
    35:38 Entry focus out binding
    37:49 Update treeview data
    44:21 Final demo app
    45:16 Closure
    #tkinter #treeview #pythongui #python3
  • НаукаНаука

Комментарии • 90

  • @kristosy
    @kristosy Месяц назад +1

    Best Tkinter channel I have found! Someone who actually explains real world intermediate/advanced scenarios instead of just "How to create a main window and place a button".

  • @lukepemberton3555
    @lukepemberton3555 Год назад

    This was so helpful. Your tkinter videos are unrivalled on the internet. Thank you so much

    • @jobinpy
      @jobinpy  Год назад

      Thanks for your kind words!

  • @prwbluz
    @prwbluz Год назад +3

    Superb Tutorial, fabulous teacher. One of the most lucid demonstrations of TreeView.

  • @vp1o2
    @vp1o2 Год назад +5

    Great tutorial. You are a very good teacher. Thank you.

  • @RaymondAlman
    @RaymondAlman Год назад +1

    this was good, love to see a simple csv file opened and updated by this method

  • @ahmedragala3946
    @ahmedragala3946 9 месяцев назад

    I've finished the tutorial, and it works perfectly! Thank you for your generosity!

  • @ahmedsaliem7041
    @ahmedsaliem7041 Месяц назад

    Really excellent tutorial that I haven't seen like it before. Thanks. Thanks again

  • @antoniobuonomo6346
    @antoniobuonomo6346 12 дней назад

    Dall' italia sei un mito continua cosi, grazie 😀molte sto imparando molto (From Italy you are a legend, keep it up, thank you very much, I'm learning a lot)

  • @user-wn9es7xp2v
    @user-wn9es7xp2v Год назад

    I ve been searching this for a week. you are my savior. Thank you very much SIR!

    • @jobinpy
      @jobinpy  Год назад

      Glad I could help!

  • @mohammedabd-allah2257
    @mohammedabd-allah2257 3 месяца назад +2

    excellent tutorial, straight to the point and addresses all needed. many thanks for sharing

    • @jobinpy
      @jobinpy  3 месяца назад

      Thanks for watching!

  • @bithepower9081
    @bithepower9081 Год назад

    My word you are a genuine genius this was VERY impressive indeed! Thank you for sharing

  • @pierreedelbruck1853
    @pierreedelbruck1853 8 месяцев назад +1

    Hi Jobin, and thank you for the nice tutorial. This was exactly what I needed. As I am french, I particularly appreciated the quality of the sound track and your crystal clear speech. About the topic, I would not have expected to have to dig in such details. I was hoping to find an editing feature out of the box in treeview. So, thank you again, Pierre.

    • @jobinpy
      @jobinpy  8 месяцев назад

      Thanks for your kind words!

  • @bolt3360
    @bolt3360 3 месяца назад +1

    Great tutorial :) Only suggestion I have is to include the code from the video as a downloadable file to make adapting it for use in other projects easier. Thank you :D

  • @curtis4u2
    @curtis4u2 5 месяцев назад

    Exactly what I needed, very well explained and easy to follow. If I can add a tip, the header height is determined by the first header column that tkinter creates. If you want to make the header taller you can add new line symbols to the beginning and end of the first column text like "
    Vehicle Type
    ". This would give you a three line header for all columns. Thanks again for this, I will be checking out your other videos as well.

    • @jobinpy
      @jobinpy  5 месяцев назад

      Great tip! Thanks for the info and thanks for watching!

  • @kevinrauer
    @kevinrauer 2 месяца назад

    What an amazing tutorial.. Thank-you so much, I am looking forward to more of your videos..

  • @YOYOLUCK88
    @YOYOLUCK88 2 года назад +1

    Very detailed explanation, thanks a lot.

  • @barrykruyssen
    @barrykruyssen Год назад

    Excellent, great subject matter and well presented.

  • @higuys638
    @higuys638 2 года назад

    This is what I've been searching for a month. Thank you so much brother. Expecting more videos and support.

  • @victorhenrique3726
    @victorhenrique3726 Год назад

    Thank you very much for the explanation, besides being a beginner, it helped me a lot because I hadn't found anything that would help with this.

    • @jobinpy
      @jobinpy  Год назад +2

      Glad it helped! Thanks for watching.

  • @krystian6364
    @krystian6364 Год назад

    Amazing video brother, thanks for the help!

  • @alipk2633
    @alipk2633 2 года назад

    this such a powerfull addition to tkinter
    thank you so much

    • @jobinpy
      @jobinpy  2 года назад +1

      Thanks for watching!

  • @jbt8903
    @jbt8903 6 месяцев назад

    Excellent Tutorial, the most advanced and Informative video I have seen. I personally learn best be example and this video taught me a lot and explained a lot of things I had questions about. Thank you for your effort. Hopefully there will be a follow up video to get into more details on developing an application. Thank You!

    • @jobinpy
      @jobinpy  6 месяцев назад

      Glad it was helpful!

  • @sumitnair7499
    @sumitnair7499 8 месяцев назад

    thanks Jobin ,.. this is video is truly amazing.. keep up the good work and share such amazing and informative videos.
    👍

    • @jobinpy
      @jobinpy  8 месяцев назад

      Thanks for your kind words!

  • @nightsky1979
    @nightsky1979 Год назад

    This tutorial is excellent!

  • @4notheruser450
    @4notheruser450 Год назад

    Thats perfect and explained very detailed thank you

    • @jobinpy
      @jobinpy  Год назад

      Glad it was helpful! Thanks for watching.

  • @videosyarego
    @videosyarego Год назад

    this video is so useful teacher, so I have a question, how to save those entries to update database by selected the rows?

  • @godsonnudzor357
    @godsonnudzor357 2 месяца назад

    Great tutorial, can i use say combo box widget than the entry widget and what about if I want the combo to replace where the sedan is only

  • @siyabonganxumalo4574
    @siyabonganxumalo4574 Год назад

    This is brilliant!

  • @davendersingh114
    @davendersingh114 2 года назад

    Thanks for explain line by line

  • @larrymarek9571
    @larrymarek9571 2 месяца назад

    This is exactly what I need! Thank you for to this great video. It would be very helpful if you made the code available, its hard to type with the video

  • @alexeymatveev9031
    @alexeymatveev9031 9 месяцев назад

    this is just grand. Thank you very much

    • @jobinpy
      @jobinpy  9 месяцев назад +1

      Glad you liked it! Thanks for watching.

  • @-sg.3665
    @-sg.3665 Год назад

    A couple of questions: Why do we record the column index and column iid? Is there a way to write pressed_on_enter without those recorded variables? I still don't understand how they work and why they should be under the entry_edit

  • @SamiVauhkonen
    @SamiVauhkonen Год назад

    Thanks, nice lesson!

  • @stevemarshall2358
    @stevemarshall2358 2 года назад +1

    Thank you

  • @Ant-up3iy
    @Ant-up3iy Год назад

    Jobin. I'm using a pandas dataframe as the source for my editable treeview. I'd like the pass any values changed in the treeview back to the dataframe. I think I need to somehow pass the dataframe (created outside the class) into the class so that it knows about it and can edit it as part of the class's 'on_enter_pressed' function, but not sure how to do it. Hoping you can help.

  • @krystian6364
    @krystian6364 Год назад

    I noticed that using "self.identify_row(event.y)" will basically do the same thing as "selected_iid = self.focus()" - both return row names like "I004", do you think using focus is better or not in this case? Why did you use focus?

  • @sungjecho552
    @sungjecho552 Год назад

    Very helpful !!!
    One question: Can you advise how to handle if a cell requires multi-lines, such as comments data ?

    • @jobinpy
      @jobinpy  Год назад +1

      Hello,
      Instead of using the Entry widget (which is limited to 1 line), you can use a different widget which supports multiple lines, such as tk.Text with a scrollbar. The text widget and scrollbar could be put into a Frame. Then set the height of the text widget to something that allows the user to type multiple lines. Then place the Frame on a treeview cell when the user wants to type something.

  • @AnyKeySkywalker
    @AnyKeySkywalker Год назад

    Спасибо, все четко и ясно.

  • @shaliniemmanuel7585
    @shaliniemmanuel7585 5 месяцев назад

    Hello Jobin, thank you for this video, this was quite useful. I have a couple of questions, can we 1. wrap the text within the cell and automatically increase the size of the row, 2. adding verical and horizontal scrollbars, 3. highlight a column and a cell individually with different color, if yes can you pl. make a video on formatting the Treeview control. thank you

  • @elciocarlos3636
    @elciocarlos3636 6 месяцев назад

    Excelente !!!

  • @ahmedragala3946
    @ahmedragala3946 9 месяцев назад

    Thanks!!

  • @bentsionben-david2769
    @bentsionben-david2769 Год назад

    How to calculate automatic math method like accountability between different columns and rows?

  • @nobertndiforazeh2191
    @nobertndiforazeh2191 Год назад +2

    Thanks very much for this tutorial Sir.
    It really helped me and works so well when I code same as you did. Please I have a little challenge Sir.
    When I create a treeview in a secondary dataframe the edit widget appears in another position from the actual cell I intend to edit, but when the new value is parsed and ‘Enter’ clicked the editing is done and the information gets in the right cell. This is also same when I change the position of the treeview in root Frame from .place(x=0, y=0) to another cordinate say .place(x=300, y=250).
    Please what can be done to correct this so that each time when I double-click the edit widget should appear just inside the cell I intend to edit as with the example you coded even in different sub-data frames having treeview.
    Thanks for your kind attention Sir.

    • @jobinpy
      @jobinpy  Год назад

      Hello. Thanks for your comment. It appears to do the same thing for me when the treeview widget does not cover the whole window (for example, if it's only taking up a small portion of the window). I will look into this, thanks.

  • @manfredschork299
    @manfredschork299 11 месяцев назад

    Great, Perfect

  • @alkareetesh8193
    @alkareetesh8193 Год назад

    How to generate grid lines in treeview sir... Please reply

  • @4notheruser450
    @4notheruser450 Год назад +1

    Can you make a video that contains searching elements without search bar and button. If user pressed any string key function will filter elements from rows and shows first matches as highligted on the middle of gui. For instances user typed "Nis" then function shows Nissan on the middle of gui as "Nis" is highlighted.
    Thanks for videos

    • @jobinpy
      @jobinpy  Год назад +1

      I'll add that idea to my list of possible tutorial topics for future videos. Thanks!

  • @1976arya
    @1976arya 6 месяцев назад

    Hello dear , I want to know how to change a single cell color (bg or fg) in treeview

  • @Ant-up3iy
    @Ant-up3iy Год назад

    Great video Jobin. What line(s) would I need to be changed when not wanting to use the "tree" column - i.e. not storing data in that column and using the following to hide it: treeview_vehicles['show'] = 'headings'

    • @jobinpy
      @jobinpy  Год назад +1

      Hi @Ant, thanks for watching. The tree column uses the 'text' option to show text in cells for that column, so anything in the video example that uses the 'text' option may not be needed in your case (for example: treeview.insert(....text="tree column text"). When the tree column is hidden, only the 'values' option in the treeview is used for displaying text (example: treeview.insert(....values=("test", "value").

    • @Ant-up3iy
      @Ant-up3iy Год назад

      @@jobinpy Thanks Jobin. I'm populating my "editable" TreeView rows from a pandas dataframe. Would be great if you could do a video on how to expand the class to update a source pandas dataframe when you enter new values in the Treeview cell.

  • @agentbanana1418
    @agentbanana1418 3 месяца назад

    Great tutorial, but when I press enter or focus out of the entry widget, the contents of the cell disappear. Why is that?

  • @qddchu976
    @qddchu976 6 месяцев назад

    this is helpful. have a question, when the entry widget is pop up, then move the scrollbar, how to move the entry widget accordingly so that the treeview table looks intact? Thank you very much

    • @qddchu976
      @qddchu976 6 месяцев назад

      or how to just simply disable the scrolling action while a cell is double clicked for editing, then resume the scrolling capability afterwards?

    • @jobinpy
      @jobinpy  6 месяцев назад +1

      One way to deal with this situation is to hide the entry widget when the treeview widget is being scrolled or when the mouse wheel is used. In Linux, which is what I use, is used for wheel up (on the mouse) and is used for wheel down.

    • @qddchu976
      @qddchu976 6 месяцев назад

      Thank you so much@@jobinpy

  • @PANDURANG99
    @PANDURANG99 Год назад

    Getting problem while number starts from zero example 00001 , it takes as 1 in tkinter treeview

  • @a1976husky
    @a1976husky Год назад

    That is a great tutorial!
    Are you offering the code for download?

    • @jobinpy
      @jobinpy  Год назад

      Thanks for watching! I don't have the code available online except in this video.

  • @user-hl3xc3fe6d
    @user-hl3xc3fe6d Год назад

    Buenos días, Alguien de casualidad tiene el código que el implemento u otro que este funcionando, tengo un error y no logro solucionarlo, y lo necesito para un proyecto de la universidad, gracias de ante mano

  • @MMMEHTA99
    @MMMEHTA99 5 месяцев назад

    great sir,plz make a video of from date to end date search data filter row in python treeview with sqlite database, i try it but not made

  • @sadioba6104
    @sadioba6104 Год назад

    the program does not manage to work on my python console I have a python version
    3.10 the latest version but when I run the program it tells me that ImportError: cannot import name 'InteractiveConsole' from 'code'
    and when I import InteractiveConsole it still doesn't work
    could you help me

    • @vp1o2
      @vp1o2 Год назад

      This is very informative. I wonder there is a Python widget like this to read/write property trees similar to the Eclipse property edit panel.

  • @nitishsharma3038
    @nitishsharma3038 Год назад

    please share code also, thanks for this tutorial

  • @frflo2476
    @frflo2476 Год назад

    t'a sauvé ma NSI, ehmercé la zone

  • @TheDev3180
    @TheDev3180 Год назад

    Please make full python course, Please

  • @funnyclips2696
    @funnyclips2696 Год назад

    Wow! This if __name__== __main__
    Of what relevant is that line pls?

    • @jobinpy
      @jobinpy  Год назад

      if __name__ == "__main__" can be interpreted as "if this python script is the main startup script for the application and not being imported by another python script."

    • @funnyclips2696
      @funnyclips2696 Год назад

      @@jobinpy But must it be included for the codes to run? Can the same objective be achieved without including that line.... It's really confusing for me!

  • @bentsionben-david2769
    @bentsionben-david2769 Год назад

    wow how to iterate (by for/while loop) between different cells in treeview a math method for example (maybe by numply/pandas):
    last rest = 10 (in column2 row1)
    new payment = 2 (in colum1 row 2)
    new rest = 8 (last rest - current payment) (in column2 row2)
    please consider to make video for this i think hondreads or thousands people will watch it

    • @jobinpy
      @jobinpy  Год назад

      Hi, thanks for your comment. I think there are multiple ways to do this. The tutorial video shows the basics of getting and setting values in a treeview cell; you could perhaps use the ideas in the video and create a method in a custom treeview class to iterate rows/cells and calculate values.

  • @user-rr2vs8zl4u
    @user-rr2vs8zl4u Год назад

    Thank You~~As Always~~!!

  • @mezdissa8388
    @mezdissa8388 Год назад

    Hello sir
    Btn.place(x=100,y=150)
    pycharm does not execute this code

  • @blackshark4609
    @blackshark4609 Год назад +2

    please upload code to github Sir.