Recalbox Forum

    • Register
    • Login
    • Search
    • Recent
    • Tags
    • recalbox.com
    • Gitlab repository
    • Documentation
    • Discord

    [TIPS] Générer une liste complete des jeux

    Recalbox Général
    [tips] générer liste complete
    6
    20
    6029
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • acris
      acris last edited by acris

      Semble qu'elle est installé : https://github.com/recalbox/recalbox-buildroot/search?utf8=✓&q=lxml&type=

      si quelque chose manque pas le choix

      • créer d'un package
      • compilation de recalboxOS
      voljega 1 Reply Last reply Reply Quote 0
      • voljega
        voljega Banned @acris last edited by

        @acris merci 🙂

        1 Reply Last reply Reply Quote 0
        • manatlan
          manatlan @voljega last edited by

          @voljega Faut pas l'utiliser à partir de la recalbox ; mais à partir d'un ordi, soit sous win, soit sous linux (moi) ... C'est beaucoup plus simple (et plus simple d'installer lxml 😉

          Il faut juste que t'as SD soit visible de l'ordi (soit par reseau (wifi), soit en partoche)
          et après, faut adapter le path (ligne : listgames("<PATH>")), en remplaçant ce dernier par le chemin vers ton répertoire "roms".

          Ca genère un CSV (pour excel ou libreoffice) ...

          Cependant, j'ai fait bien mieux depuis, je génère un HTML/JS, qui présente un tableau dans lequel tu peux filtrer par nom, console, genre, année ... bien plus pratique ...
          si ça interesse qqu'un, je le posterai ici

          voljega 1 Reply Last reply Reply Quote 0
          • acris
            acris last edited by

            @manatlan
            pourquoi pas voir avec @DjLeChuck si il serait possible d'ajouter cette fonctionnalité dans le recalbox Manager
            https://forum.recalbox.com/topic/3768/wip-recalbox-manager

            ça pourrait peut être intéressant

            DjLeChuck 1 Reply Last reply Reply Quote 0
            • voljega
              voljega Banned @manatlan last edited by

              @manatlan en fait je demandai car je me mets à Python en ce moment et j'ai deux trois idées de scripts avec les fichiers xml de recalbox

              manatlan 1 Reply Last reply Reply Quote 0
              • DjLeChuck
                DjLeChuck @acris last edited by

                @acris Quoi quoi on m'appelle ? \o/
                Mettre l'export CSV ? Ça peut être sympa en effet !

                @manatlan pour que ton script soit encore un peu plus simple à utiliser, tu pourrais mettre le chemin vers les ROMs en arguments et récupérer sa valeur via sys.argv (https://www.tutorialspoint.com/python/python_command_line_arguments.htm)

                manatlan 1 Reply Last reply Reply Quote 0
                • acris
                  acris last edited by

                  @DjLeChuck oui tout à fait 😄
                  j'ajouterai pour ajouter la possibilité de créer une liste en utilisant gamelist.xml pour extraire les jeux de 2 joueurs, 4 joueurs et par type (plateforme, shoot em up) etc.. pourraient être intéressant 😄

                  DjLeChuck manatlan 2 Replies Last reply Reply Quote 0
                  • DjLeChuck
                    DjLeChuck @acris last edited by

                    @acris À rajouter sur la TODO list: https://github.com/DjLeChuck/recalbox-manager/issues ^^

                    1 Reply Last reply Reply Quote 0
                    • acris
                      acris last edited by

                      @DjLeChuck
                      voila fait : https://github.com/DjLeChuck/recalbox-manager/issues/40
                      désolé en français car encore bien réveillé pour de l'anglais.

                      DjLeChuck 1 Reply Last reply Reply Quote 0
                      • DjLeChuck
                        DjLeChuck @acris last edited by

                        @acris Oh je ne demande pas à ce que mes tickets soient en anglais de toute façon, ils peuvent aussi être en français ! 😄

                        1 Reply Last reply Reply Quote 0
                        • manatlan
                          manatlan @voljega last edited by

                          @voljega a ce moment là, pas la peine d'utiliser LXML, python est installée avec d'autres libs natives pour pa**er la dom xml ...
                          moi, j'ai utilisé lxml, car c'est la plus rapide, et celle que j'utilise tout le temps 😉

                          voljega 1 Reply Last reply Reply Quote 0
                          • manatlan
                            manatlan @DjLeChuck last edited by

                            @DjLeChuck ... j'ai un bon niveau en python, je connais tout ça 😉
                            je ne l'ai pas mis en arg, car pour un utilisateur donné, il n'y a qu'un seul path (aka ça change pas tout le temps 😉

                            Sinon, si le "manager" est en python, je veux bien mettre les mains dedans, avec plaisir. J'ai 20ans de python, de web/http/js et j'en passe 😉

                            1 Reply Last reply Reply Quote 0
                            • manatlan
                              manatlan @acris last edited by

                              @acris le hic, c'est que les scrapping sont rarement bons ... le genre, ça passe encore (mais il y a plein de genre pour un même genre (je me comprends ;-)) ... mais le nb de joueurs est très rarement juste ;-(
                              Mais dans l'absolu, c'est clair que ce serait géant ...

                              voilà un exemple de ce que je genere :
                              http://in-the.appspot.com/recalbox/

                              1 Reply Last reply Reply Quote 0
                              • acris
                                acris last edited by acris

                                On utilise screenscraper dont la base de donnée est relativement nouvelle, je pense que les informations sont correctes.
                                autant faire un truc complet que partiel.

                                @manatlan pas mal ton exemple, tout ne fonctionne pas mais c'est super intéressant sur des romsets complets no-intro ça doit bien donnée.
                                manquerait plus de pouvoir créer un dat pour faire le tri avec clrmamepro comme il le fait avec les roms parent et clones ahaha

                                1 Reply Last reply Reply Quote 0
                                • voljega
                                  voljega Banned @manatlan last edited by

                                  @manatlan ben je me mets tout juste au python donc bon là j'ai un exemple, c'est aussi bien pour commencer... on peut écrire aussi du xml avec lxml ?

                                  sinon des exemples d'autres libs ou fonctions faciles à utiliser ?

                                  manatlan 1 Reply Last reply Reply Quote 0
                                  • manatlan
                                    manatlan @voljega last edited by

                                    @voljega Oui, avec lxml tu peux sans soucis, c'est même conseillé. Cependant, même les libs internes de python le peuvent (elles sont juste un poil plus lentes (aucune n'est plus rapide que lxml))

                                    Voilà mon script qui génère un fichier "liste.js" :

                                    #!/usr/bin/python
                                    # -*- coding: utf-8 -*-
                                    import os,glob,collections,json
                                    from lxml.etree import pa&ast;&ast;e
                                    
                                    Game = collections.namedtuple('Game', 'console name genre date image path')
                                    
                                    def listgames(p,opt="*"):
                                    
                                        def get(i,e):
                                            ll=i.xpath(e)
                                            return ll[0].text if ll else None
                                    
                                        ll=[]
                                        for f in sorted(glob.glob( os.path.join(p,opt,"gamelist.xml") )):
                                            try:
                                                for i in pa&ast;&ast;e(f).xpath("//game"):
                                                    fpath=os.path.dirname(f)
                                                    console=os.path.basename(fpath)
                                    
                                                    name,genre,date,image=get(i,"name"),get(i,"genre"),get(i,"releasedate"),get(i,"image")
                                                    path = os.path.realpath(os.path.join(fpath,get(i,"path")))
                                    
                                                    if get(i,"hidden")=="true": continue                                # zap hidden
                                                    if genre and genre.strip().lower().startswith("bios"): continue     # zap bios file
                                                    if image: image = os.path.join( fpath, image )                      # create realpath to image
                                                    if date: date=date.strip()[:4]                                      # keep just the year
                                    
                                                    ll.append( Game(console,name,genre,date,image,path) )
                                            except Exception as e:
                                                print "Fichier XML invalide:",f,e
                                        return ll
                                    
                                    def genJS(ll):
                                        ll=[{"name":i.name,"console":i.console,"genre":i.genre or "NO GENRE","year":i.date or "NO YEAR","image":i.image} for i in ll]
                                        with open('liste.js', 'w') as fid:
                                            fid.write("var liste=");
                                            json.dump(ll, fid)
                                    
                                    if __name__ == "__main__":
                                        ll=listgames("/media/recalbox/roms")    # <--- just edit here !!!
                                    
                                        print( len(ll) )
                                        genJS(ll)
                                    

                                    Ce fichier est chargé par https://in-the.appspot.com/recalbox/index.html ...
                                    (du coup, si vous voulez le faire chez vous, suffit de recupérer cet "index.html" (show source, ou le télécharger, et de mettre le liste.js généré par le script python)

                                    C'est juste un "index.html" de base (y a juste le css minimum, mais on peut trier les colonnes 😉

                                    1 Reply Last reply Reply Quote 0
                                    • alex28700
                                      alex28700 last edited by

                                      Bonjour tous ! Je trouve la fonction hyper intéressante, y a t-il eu des développements sur cette idée ? Elle semble être tombée aux oubliettes car ce sujet a 3 ans et la fonctionnalité n'est pas apparue depuis sur recalbox manager...

                                      Je n'ai pas réussi à tirer quelque chose du script de @manatlan (merci au passage du partage, je suis assez mauvais en programmation mais je ne lâche pas l'affaire !)

                                      J'ai utilisé le premier script, celui qui sort un csv.

                                      • Install de Python 3.8.1 et librairie lxml 4.4.2
                                      • J'édite le script pour y inclure vers le répertoire des roms que j'ai copié sur mon bureau "E:\Bureau\roms"
                                      • Je lance le script
                                      • Ca me sort un csv mais il est vide...

                                      Si vous avez des pistes pour faire fonctionner le script je suis preneur, ou si depuis quelque chose d'autre a été developpé encore mieux, merci d'avance !

                                      1 Reply Last reply Reply Quote 0
                                      • First post
                                        Last post

                                      Want to support us ?

                                      84
                                      Online

                                      99.6k
                                      Users

                                      28.1k
                                      Topics

                                      187.1k
                                      Posts

                                      Copyright © 2021 recalbox.com