Skip to content

Python - Dict -> JSON und umgekehrt

Python3
1 1 340
  • Ich möchte hier noch mal was für Einsteiger ablegen. Man hat ja am Anfang immer so das Problem, wie speichere ich meine Daten dauerhaft und lade diese wieder!? Das hat mir am Anfang viele Kopfschmerzen beschert. Hier mal ein Listing, wie man das so grob mal ausprobieren kann.

    import json
    
    # instantiate an empty dict
    backups = {}
    
    # add some data
    backups[0] = {'name': 'Test', 'repository': '/home/frankm/repo1'}
    backups[1] = {'name': 'Haupt-PC', 'repository': '/home/frankm/repo2'}
    backups[2] = {'name': 'NAS', 'repository': '/home/frankm/repo3'}
    
    # print some data
    print(backups)
    
    print('------')
    
    print(backups[1])
    
    print('------')
    
    print(backups[1]['name'])
    
    print('------')
    
    # save backups to JSON
    with open('mydata.json', 'w') as f:
        json.dump(backups, f)
    
    # print values
    for i in backups.values():
        print(i)
    
    print('------')
    
    # output
    # {'name': 'Test', 'repository': '/home/frankm/repo1'}
    # {'name': 'Haupt-PC', 'repository': '/home/frankm/repo2'}
    # {'name': 'NAS', 'repository': '/home/frankm/repo3'}
    
    # load JSON
    with (open('mydata.json', 'r')) as f:
        backups_reload = json.load(f)
    
    # Test
    for i in backups_reload.values():
        print(i)
    
    print('------')
    
    # Print keys
    # Delete key_list
    keys_list = []
    
    # redo keys_list
    for key in backups:
        keys_list.append(key)
    
    print(keys_list)
    
    print('------')
    
    # delete an entry
    result = backups.pop(1, False)
    if not result:
        print('Error')
    
    # Kontrolle
    for i in backups.values():
        print(i)
    
    print('------')
    
    # Print keys
    # Delete key_list
    keys_list = []
    
    # redo keys_list
    for key in backups:
        keys_list.append(key)
    
    print(keys_list)
    
    print('------')
    
    # Print last key
    print(list(dict.keys(backups))[-1])
    
    print('------')
    
    print(type(list(dict.keys(backups))[-1]))
    
    # Add new entry
    backups[list(dict.keys(backups))[-1]+1] = {'name': 'Test', 'repository': '/home/frankm/repo1'}
    
    print('------')
    
    # Print keys
    # Delete key_list
    keys_list = []
    
    # redo keys_list
    for key in backups:
        keys_list.append(key)
    
    print(keys_list)
    

    Wir erstellen ein DICT, fülle das mit Daten. Danach speichern wir als JSON. Das JSON wird wieder geladen, in ein anderes DICT (zur Kontrolle).

    Dann löschen wir einen Eintrag, legen einen neuen an und geben das aus.

    Dazwischen findet man immer wieder ein paar Kontrollausgaben, das sieht am Schluss dann so aus.

    {0: {'name': 'Test', 'repository': '/home/frankm/repo1'}, 1: {'name': 'Haupt-PC', 'repository': '/home/frankm/repo2'}, 2: {'name': 'NAS', 'repository': '/home/frankm/repo3'}}
    ------
    {'name': 'Haupt-PC', 'repository': '/home/frankm/repo2'}
    ------
    Haupt-PC
    ------
    {'name': 'Test', 'repository': '/home/frankm/repo1'}
    {'name': 'Haupt-PC', 'repository': '/home/frankm/repo2'}
    {'name': 'NAS', 'repository': '/home/frankm/repo3'}
    ------
    {'name': 'Test', 'repository': '/home/frankm/repo1'}
    {'name': 'Haupt-PC', 'repository': '/home/frankm/repo2'}
    {'name': 'NAS', 'repository': '/home/frankm/repo3'}
    ------
    [0, 1, 2]
    ------
    {'name': 'Test', 'repository': '/home/frankm/repo1'}
    {'name': 'NAS', 'repository': '/home/frankm/repo3'}
    ------
    [0, 2]
    ------
    2
    ------
    <class 'int'>
    ------
    [0, 2, 3]
    
    Process finished with exit code 0
    

    Ich hoffe das es dem ein oder anderem das Leben etwas einfacher macht.

  • FrankMF FrankM hat am auf dieses Thema verwiesen
  • FreeOTP+ Datenumzug nach Bitwarden Authenticator

    Python3 ki-generiert python
    1
    0 Stimmen
    1 Beiträge
    214 Aufrufe
    Niemand hat geantwortet
  • Flask Projekt auf einem anderen Rechner installieren

    Python3 python flask linux
    1
    0 Stimmen
    1 Beiträge
    183 Aufrufe
    Niemand hat geantwortet
  • Pycharm - Umzug auf neuen Rechner

    Linux pycharm linux python
    1
    0 Stimmen
    1 Beiträge
    127 Aufrufe
    Niemand hat geantwortet
  • PyWebIO - put_buttons

    PyWebIO pywebio python
    2
    1
    0 Stimmen
    2 Beiträge
    222 Aufrufe
    FrankMF
    Und noch eine kleine Übung, wie man den Buttton abhängig von einem Value enabled/disabled # we build header and tdata for table tab_mount = [] for count, value in enumerate(backups): if count == 0: tab_mount.append(['No.', 'Backup name of the restic data backup', 'Actions']) if backups[value].init == "0": tab_mount.append([count + 1, backups[count].name, put_buttons([ dict(label='Mount', value='Mount', color='primary', disabled=True), dict(label='UMount', value='UMount', color='primary', disabled=True), dict(label='Restore', value='Restore', color='primary', disabled=True), ] , onclick=partial(actions, count + 1)) ]) else: tab_mount.append([count + 1, backups[count].name, put_buttons([ dict(label='Mount', value='Mount', color='primary'), dict(label='UMount', value='UMount', color='primary'), dict(label='Restore', value='Restore', color='primary'), ], onclick=partial(actions, count + 1)) ])
  • Python3 - VSCodium Language Settings

    Python3 python
    3
    3
    0 Stimmen
    3 Beiträge
    219 Aufrufe
    FrankMF
    Ich habe da jetzt gestern stundenlang mit rum gespielt, insbesondere Deinstallation, Neuinstallation, VSCode Installation usw. Das ging einfach nicht. Irgendwo meine ich dann gelesen zu haben, das VSCode auf python 3.9 festgenagelt ist und deswegen so einige Dinge nicht gehen. Nagelt mich darauf nicht fest, ich bin in dieser Coding Welt kein Profi. Dann fiel mir ein, das ich schon vor einigen Monaten mal kurz einen Blick in Pycharm geworfen hatte. Gefiel mir damals gar nicht. Das habe ich heute mal auf die Platte geworfen um zu schauen, ob das vernünftig mit dem o.g. Problem umgehen kann. [image: 1662928323311-6f1c3906-05a3-4126-81d4-7fdf6aa27faa-grafik.png] Puuuh, da kann man ja noch viel mehr einstellen als bei VSCode, oder mindestens ähnlich viel. Das kann einen ganz schön überfordern. Also Stück für Stück die nächsten Tage. Was ist mir positiv aufgefallen? Wenn ich VSCodium neu installiert habe, habe ich unheimlich mit Python Versionen, pipenv usw. zu kämpfen gehabt. Bis da mein Projekt wieder lief, konnte schon mal was Zeit vergehen. Mit Pycharm Ordner ausgewählt, angeklickt das man dem Coder vertraut. Noch eine Python Version ausgewählt, danach fragt er das er eine pipenv Umgebung gefunden hat und diese nutzen möchte. Ja angeklickt und fertig. Keine zwei Minuten und das Projekt lief wieder Erster Git Commit ging auch sofort und ohne Murren. Schon mal ganz viele Pluspunkte gesammelt. Was mich aktuell beschäftigt, ist der Tab Problems, da hatte ich vorher deutlich weniger. Da muss ich mich noch was einarbeiten und schauen, wo man das alles einstellen kann. Ich halte euch auf dem Laufenden.. Vielleicht fliegt ja das VSCo** Zeug runter!? Mal sehen..
  • Qt 5 Designer

    Python3 python
    1
    4
    0 Stimmen
    1 Beiträge
    141 Aufrufe
    Niemand hat geantwortet
  • PyQt6 - QSettings

    Python3 python
    3
    0 Stimmen
    3 Beiträge
    453 Aufrufe
    FrankMF
    Möglichkeit 1 Das hier settings = QSettings("Frank_Mankel", "Restic_UI") erzeugt unter /home/frank/.config/Frank_Mankel/Restic_UI.conf die Konfigurationsdatei. Möglichkeit 2 Das hier settings = QSettings("Restic_UI") erzeugt unter /home/frank/.config/Restic_UI.conf die Konfigurationsdatei. Damit habe ich die grundlegenden Dinge, hoffentlich , verstanden. Für den Rest mal in die Dokumentation schauen. Sehr hilfreich war auch mal ein Blick auf die Definition der Klasse. Rechtsklick auf QSettings und dann Go to Definition class QSettings(QObject): class Scope(enum.Enum): UserScope = ... # type: QSettings.Scope SystemScope = ... # type: QSettings.Scope class Format(enum.Enum): NativeFormat = ... # type: QSettings.Format IniFormat = ... # type: QSettings.Format InvalidFormat = ... # type: QSettings.Format class Status(enum.Enum): NoError = ... # type: QSettings.Status AccessError = ... # type: QSettings.Status FormatError = ... # type: QSettings.Status [..gekürzt..]
  • Restic UI - REST Server Unterstützung

    Restic UI restic-ui restic rest-server python
    2
    0 Stimmen
    2 Beiträge
    295 Aufrufe
    FrankMF
    Die REST Unterstützung ist komplett https://gitlab.com/Bullet64/restic-ui-public/-/releases/1.1.0 Ich denke, ein wenig Dokumentation wäre noch gut