IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Python Discussion :

Solution pour copier dans le presse-papier (clipboard)


Sujet :

Python

  1. #1
    Invité
    Invité(e)
    Par défaut Solution pour copier dans le presse-papier (clipboard)
    Bonjour,

    Je viens de galérer toute la nuit (en témoigne l'heure de mon post) pour trouver une façon de copier une variable string dans le "clipboard" (presse-papier), les solutions proposées sur le net fonctionnent bien si on a pas besoin de copier une chaine de caractères qui peut contenir des combinaisons du genre "\n" (retour à la ligne) , "\t" (tabulation), "|" (caractère réservé pour cmd.exe)...
    Quand on veut copier un mot de passe, il y a des chances que ces combinaisons soient présentes donc voici ma petite solution pour éviter que le système ne transforme un "\n" en retour à la ligne par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    mdp="e|8_P\n\t\v"
    t = open("roaming_clipboard.txt","w")
    raw_mdp = r"{}".format(mdp)
    t.write(raw_mdp)
    t.close()
    os.system("CLIP < roaming_clipboard.txt")
    os.remove("roaming_clipboard.txt")
    Et voilà ! Il ne reste plus qu'à faire un CTRL+V...

    Sur ce bonne journée !

  2. #2
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Bonjour

    Déjà ce n'est pas l'endroit pour poster ce genre de tuto. Il y a une zone du forum pour ça où tu peux poster tes sources et leur but.
    Mais sinon, c'est besoin d'écrire un fichier sur disque ? On peut pas faire un subprocess.popen() pour écrire directement dans la commande "clip" ? (là je peux pas tester je n'ai pas de zindow avec Python de dispo). En tout cas, on peut très bien écrire depuis une fenêtre MsDos type roaming_clipboard.txt |clip et ça marche alors on doit pouvoir le faire depuis Python et se passer du fichier.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  3. #3
    Expert éminent
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 462
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 462
    Points : 9 249
    Points
    9 249
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Bravo pour l'idée! En essayant de se passer d'une écriture sur un fichier du disque, on peut utiliser un fichier en mémoire:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    import io
    import subprocess
     
    ##############################################################################
    def copieclip(texte):
        """Copie le texte dans le presse-papier de Windows (spécifique Windows!)
        """
        raw_texte = r"{}".format(texte)
        with io.FileIO("fichierclip", "w") as fs:
            fs.write(bytes(raw_texte, encoding="cp850"))
        subprocess.run(["CLIP", "<", "fichierclip"], shell=True)
     
    ##############################################################################
    texte1 = """e|8_P'é"àç\n\t\v"""
    copieclip(texte1)
    J'ai complexifié un peu le texte à envoyer en ajoutant des caractères supplémentaires: ', ", é, à, ç et ça a l'air de fonctionner.

    Pour récupérer le texte du presse-papier, on fait "Ctrl-V", mais ce serait bien d'avoir aussi une version Python. Par exemple avec powershell, utilisé ici à partir de la console normale (cmd.exe):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    ##############################################################################
    def pasteclip():
        """Récupère le texte du presse-papier de Windows (utilise cmd.exe)
        """
        with subprocess.Popen(["powershell", "get-clipboard"], stdout=subprocess.PIPE) as proc:
            return str(proc.stdout.read(), "cp850")
    Mais j'ai un problème avec ce dernier code: à chaque LF, il convertit en RC+LF ce qui ajoute des caractères en trop, et il en rajoute même un RC+LF à la fin. Si quelqu'un a une idée?
    Un expert est une personne qui a fait toutes les erreurs qui peuvent être faites, dans un domaine étroit... (Niels Bohr)
    Mes recettes python: http://www.jpvweb.com

  4. #4
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Points : 22 933
    Points
    22 933
    Billets dans le blog
    125
    Par défaut


    Une autre solution :

    Code Python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    import pyperclip  # https://pypi.org/project/pyperclip/
     
    pyperclip.copy('The text to be copied to the clipboard.')
     
    print(pyperclip.paste())
     
    pyperclip.copy(r"""e|8_P'é"àç\n\t\v""")
     
    print(pyperclip.paste())

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  5. #5
    Invité
    Invité(e)
    Par défaut
    Salut Sve@r !
    Désolé pour le placement du topic !
    subprocess pour moi c'est du charabiat

    Salut @tyrtamos !
    Une solution pour coller :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    from tkinter import Tk
    def pasteclip():
        """Récupère le texte du presse-papier de Windows (utilise cmd.exe)
        """
        r = Tk()
        print(r.clipboard_get())
        r.destroy()
    Salut @danielhagnoul !
    Tu triches tu mets direct un raw string et avec une variable string comment qu'est que je fais pour que la solution elle soit vite trouvée ?
    Plus sérieusement, j'ai toujours eu beaucoup de mal à gérer les formats, l'encodage des strings et tout le tintouin...

  6. #6
    Membre expérimenté
    Avatar de MPython Alaplancha
    Homme Profil pro
    Paysan à 3 francs six sous
    Inscrit en
    Juin 2018
    Messages
    870
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Paysan à 3 francs six sous
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Juin 2018
    Messages : 870
    Points : 1 522
    Points
    1 522
    Billets dans le blog
    4
    Par défaut
    Citation Envoyé par LeNarvalo Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    from tkinter import Tk
    def pasteclip():
        """Récupère le texte du presse-papier de Windows (utilise cmd.exe)
        """
    Bonjour,
    Précision: la solution tkinter(clipboard_get()) fonctionne aussi sur système gnu/linux...
    #Rien de nouveau sous le soleil, tout est vanité comme courir après le vent!
    Developpement pour Android avec Python3/Kivy/Buildozer

  7. #7
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par LeNarvalo Voir le message
    subprocess pour moi c'est du charabiat
    Oh ben tout s'apprend. Il y a des exemples qui permettent de comprendre le principe. L'ingorance est de courte durée, la connaissance reste à vie (enfin jusqu'à Alzeihmer)

    Citation Envoyé par LeNarvalo Voir le message
    Plus sérieusement, j'ai toujours eu beaucoup de mal à gérer les formats, l'encodage des strings et tout le tintouin...
    Oui, c'est pas évident.
    Pour faire simple, tout ce qui est dans Python c'est de l'unicode. Tout ce qui entre doit donc être converti en unicode le plus tôt possible (la fonction str.decode() peut t'y aider). Et tout ce qui sort doit être converti dans l'encoding de sortie (probablement utf8) le plus tard possible via str.encode().
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  8. #8
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Il y a des exemples qui permettent de comprendre le principe. .
    Les exemples sont rarement clairs pour subprocess.popen et ça marche jamais chez moi...
    C'est moi qui déconne ou subprocess.popen est surtout utilisé pour Linux ?

  9. #9
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par LeNarvalo Voir le message
    Les exemples sont rarement clairs pour subprocess.popen et ça marche jamais chez moi...
    Ah ben oui, il faut juste comprendre le principe ensuite ça va tout seul (mais connaitre les processus Unix, stdin, stdout, l'enchainement de pipes, ça aide quand-même bien).

    Quand on crée un subprocess.Popen(commande), ce qu'il faut bien gérer c'est "comment faire rentrer des trucs" et "où va aller la commande".
    Prenons un exemple de base, un simple "ls -l" (ou un "dir" sous zindow). Cette commande se suffit à elle-même, rien à saisir et l'affichage va direct à l'écran .
    Le code sera donc
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    subprocess.Popen(
    	("ls", "-l"),
    	stdin=None,			# Facultatif
    	stdout=None,			# Facultatif
    )
    Les valeurs "None" pour stdin et stdout signifiant que les entrées et sorties ne seront pas modifiées par rapport au standard (clavier/écran). Et quand c'est None, c'est facultatif (enfin je crois).

    Maintenant, tu veux traiter ce "ls -l" dans un traitement à toi depuis Python. Il va te falloir alors déjà demander à ce que la sortie stdout n'aille pas vers l'écran mais vers Python. Cela se fait grace à "PIPE". Et dans Python, tu récupères simplement le stdout du process comme si c'était un fichier que tu lis.

    Bon pour l'exemple le traitement sera simplement un enumerate et un affichage de ce qui est reçu. Et pour simplifier l'écriture, on va mémoriser le subprocess dans une variable pour éviter de tout écrire sur une énorme et imbitable ligne.

    Le code devient donc
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    p1=subprocess.Popen(
    	("ls", "-l"),
    	stdin=None,
    	stdout=subprocess.PIPE,
    )
     
    for (i, l) in enumerate(p1.stdout, 1):
    	print("Ligne %d: %s" % (i, l))

    Maintenant on veut rajouter un traitement intermédiaire, comme par exemple convertir la sortie du "ls" en majuscules via la commande "tr". On va alors rajouter un second subprocess sur "tr" qui récupère en entrée la sortie du premier subprocess sur "ls" pour le convertir.
    Et le traitement lui (toujours un enumerate) s'appliquera non plus sur la sortie de "ls" mais celle de "tr".

    Le code devient
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    p1=subprocess.Popen(
    	("ls", "-l"),
    	stdin=None,
    	stdout=subprocess.PIPE,
    )
     
    p2=subprocess.Popen(
    	("tr", "[:lower:]", "[:upper:]"),
    	stdin=p1.stdout,
    	stdout=subprocess.PIPE,
    )
     
    for (i, l) in enumerate(p2.stdout, 1):
    	print("Ligne %d: %s" % (i, l))

    Voilà. T'as maintenant les bases pour chainer des commandes les unes à la suite des autres. stdout est toujours subprocess.PIPE et stdin récupère le stdout du subprocess précédent.

    Ce qui m'a permis de créer cet automate
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    def chain_command(liste_cmd):
    	prev=None
    	for cmd in liste_cmd:
    		current=subprocess.Popen(
    			cmd,
    			stdin=prev.stdout if prev is not None else None,
    			stdout=subprocess.PIPE,
    		)
    		prev=current
    	# for
    	return current
    # chain_command

    Et de pouvoir l'utiliser ainsi
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    for line in chain_command(
    	(
    		("cat", "/etc/passwd"),
    		("tr", "[:lower:]", "[:upper:]"),
    		("cut", "-f6", "-d:"),
    		"sort",
    		("awk", "{print $0 $0}"),
    		("tr", "[:upper:]", "[:lower:]"),
    	)
    ).stdout: print("\t%s" % line.strip().decode("utf-8"))

    Et pour ton clip, puisque là c'est l'inverse (on veut non pas traiter ce qui sort de la commande "clip" mais y écrire des trucs), le code devrait ressembler à ceci
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    p=subprocess.Popen("CLIP", stdin=subprocess.PIPE, stdout=None)
    for txt in (..., ..., ..., ...):
    	p.stdin.write(("%s\n" % txt).encode("utf-8"))
    .

    Citation Envoyé par LeNarvalo Voir le message
    C'est moi qui déconne ou subprocess.popen est surtout utilisé pour Linux ?
    A la base le pipe est quand-même bien un outil Unix donc il est normal que toutes les technos qui l'impémentent le soient tous Unix (et tous mes exemples ont été pris à partir de commandes Unix). Mais maintenant Windows s'y est mis donc ça marche aussi.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  10. #10
    Invité
    Invité(e)
    Par défaut
    Pfff ! C'est quand même pas très clair pour ma petite tête, j'y arrive toujours pas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    import subprocess
     
    p1=subprocess.Popen(
    	("dir"),
    	stdin=None,
    	stdout=subprocess.PIPE,
    )
     
    for (i, l) in enumerate(p1.stdout, 1):
    	print("Ligne %d: %s" % (i, l))
    >>> Résultat :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
      File "C:\Python37\lib\subprocess.py", line 775, in __init__
        restore_signals, start_new_session)
      File "C:\Python37\lib\subprocess.py", line 1178, in _execute_child
        startupinfo)
    FileNotFoundError: [WinError 2] Le fichier spécifié est introuvable
    Et pour ton dernier bout de code, ben ça marche pas... ='( Je vais encore bidouiller ça pdt 2h, je le sens !

  11. #11
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par LeNarvalo Voir le message
    j'y arrive toujours pas
    Il faut lire les messages d'erreur. Ce n'est pas un souci de subprocess qui s'exécute mais qui ne produit pas le bon résultat, c'est un souci de subprocess qui ne trouve pas la commande "dir" et qui donc ne peut pas s'exécuter. Ce qui est normal car "dir" ce n'est pas une commande externe (style dir.exe) mais une instruction interne MsDos. Normal que Python ne la trouve pas.

    Remplace "dir" par "calc.exe" et là ça marche. Bon sauf que comme la commande n'écrit rien sur stdout tu n'obtiens rien dans l'enumerate. Et c'est donc peut-etre là qu'on sent que subprocess va devenir effectivement beaucoup moins intéressant sous zindow que sous Unix/Linux qui a justement été fait pour ça et rempli de milliers de petites commandes qui ne font qu'une action mais qui la font bien et qui, surtout, toutes, lisent stdin et écrivent dans stdout. Ce qui permet alors de les chainer via des pipes pour produire des traitements et résultats complexes (une fois pour convertir un fichier écrit dans sais plus quel format en fichier format ldap je suis passé par 7 pipes).

    Et au fait, mon exemple de clip fonctionne.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  12. #12
    Invité
    Invité(e)
    Par défaut
    Merci mais je suis un cas désespéré... Je capte rien du tout même le message d'erreur, on pourrait faire plus clair je trouve FileNotFoundError: [WinError 2] Le fichier spécifié est introuvable.
    [WinError 2] ça veut dire quoi ?
    Je me doutais bien que c'était dir qui ne fonctionnait pas, vu que j'avais tapé ça sans savoir ce que je faisais...

    PS : Je peux même pas tester avec calc.exe car je ne l'ai plus mon ordi ! Faut pas me laisser un ordi entre les mains ! (J'ai supprimé Windows Store et en faite plein d'applications de base sont dedans... Messagerie Windows, calculette, visionneuse d'images, ...)

  13. #13
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par LeNarvalo Voir le message
    Merci mais je suis un cas désespéré... Je capte rien du tout même le message d'erreur, on pourrait faire plus clair je trouve FileNotFoundError: [WinError 2] Le fichier spécifié est introuvable.
    Ben c'est plutôt clair. Verbe, sujet, complément. Ok il y aurait le nom du truc introuvable ça aurait aidé mais comme il n'y a qu'un paramètre que tu entres, il est fatal que le truc introuvable ce soit ledit paramètre.

    Citation Envoyé par LeNarvalo Voir le message
    [WinError 2] ça veut dire quoi ?
    Ca j'en n'ai aucune idée. Ca doit être un code retour venu de windows.

    Citation Envoyé par LeNarvalo Voir le message
    PS : Je peux même pas tester avec calc.exe car je ne l'ai plus mon ordi ! Faut pas me laisser un ordi entre les mains ! (J'ai supprimé Windows Store et en faite plein d'applications de base sont dedans... Messagerie Windows, calculette, visionneuse d'images, ...)
    Sais pas comment t'as fait parce que moi aussi je voulais le faire mais c'est en grisé. Quoi qu'il en soit tu dois encore avoir paint.exe, regedit.exe, notepad.exe, write.exe ou même des trucs que t'as toi-même installé style notepad++.exe, word.exe, etc. Sinon au pire tu te crées un petit truc en python qui génère quelques phrases à la con et qui les affiche à l'écran (print()) puis tu fais exécuter ce petit truc via subprocess (car c'est ça le test, récupérer ce qui a été affiché par un autre programme)
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    import subprocess
     
    p1=subprocess.Popen(
    	("python.exe", "petit_truc.py"),
    	stdin=None,
    	stdout=subprocess.PIPE,
    )
     
    for (i, l) in enumerate(p1.stdout, 1):
    	print("Ligne %d: %s" % (i, l))

    Et puis sinon l'idée initialie c'était d'envoyer des trucs dans clip. Ca tu l'as puisque tu l'as fait depuis un fichier. Et donc comme je t'ai dit, en testant sous windows hier j'ai testé aussi mon code qui a fonctionné
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    p=subprocess.Popen("CLIP", stdin=subprocess.PIPE, stdout=None)
    for txt in (..., ..., ..., ...):
    	p.stdin.write(("%s\n" % txt).encode("utf-8"))
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  14. #14
    Expert éminent
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 462
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 462
    Points : 9 249
    Points
    9 249
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    On peut appeler 2 catégories d'exécutables dans la console Windows:
    - des fonctions qui font partie de la console comme "dir"
    - des fichiers exécutables comme "calc.exe"

    Par défaut, subprocess.Popen n'appelle que des fichiers exécutables. Et comme "dir" n'en fait pas partie (la console ne trouve pas le fichier "dir.exe!), cela donne l'erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    FileNotFoundError: [WinError 2] Le fichier spécifié est introuvable
    WinError signifie que c'est une erreur renvoyée par Windows (en fait sa console cmd.exe) et non une erreur interne à Python. Mais en fait, l'erreur Windows vient d'une mauvaise demande faite par le code Python.

    Si on veut appeler une fonction de la console, il faut le préciser avec un argument supplémentaire: "shell=True". Ainsi corrigé, le code fonctionne:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    import subprocess
     
    p1=subprocess.Popen(
        ("dir"),
        stdin=None,
        stdout=subprocess.PIPE,
        shell=True
    )
     
    for (i, l) in enumerate(p1.stdout, 1):
        print("Ligne %d: %s" % (i, l))
    En ce qui me concerne, je me sens incapable de programmer correctement (et en comprenant ce que je fais), sans consulter la documentation. Pour subprocess, c'est là, et on peut même l'avoir en français:
    https://docs.python.org/fr/3/library...ule-subprocess
    Un expert est une personne qui a fait toutes les erreurs qui peuvent être faites, dans un domaine étroit... (Niels Bohr)
    Mes recettes python: http://www.jpvweb.com

  15. #15
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par tyrtamos Voir le message
    Si on veut appeler une fonction de la console, il faut le préciser avec un argument supplémentaire: "shell=True".
    Ah j'avais jamais pigé le rôle de ce paramètre (et la doc n'est pas super claire à ce sujet car elle dit que ça fait appeler le programme invoqué par un shell ce qui est un comportement plutôt standard sous Linux) donc bon j'avais mis ça de côté.
    Merci

    Citation Envoyé par tyrtamos Voir le message
    En ce qui me concerne, je me sens incapable de programmer correctement (et en comprenant ce que je fais), sans consulter la documentation.
    Je le fais aussi. Mais parfois............ la doc n'est pas super claire...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  16. #16
    Expert éminent
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 462
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 462
    Points : 9 249
    Points
    9 249
    Billets dans le blog
    6
    Par défaut
    On trouve tout de même quelques explications dans la doc. Extrait de la doc (version française) concernant shell=True:

    La seule raison pour laquelle vous devriez spécifier shell=True sous Windows est quand la commande que vous souhaitez exécuter est une built-in du shell (p. ex. dir ou copy). Vous n'avez pas besoin de shell=True pour lancer un fichier batch ou un exécutable console.
    Il est par contre mentionné que ça peut poser quelques problèmes de sécurité, et c'est probablement pour ça que ce n'est jamais le mode par défaut:
    https://docs.python.org/fr/3/library...considerations

    En particulier pour éviter les injections:
    https://en.wikipedia.org/wiki/Code_i...hell_injection
    Un expert est une personne qui a fait toutes les erreurs qui peuvent être faites, dans un domaine étroit... (Niels Bohr)
    Mes recettes python: http://www.jpvweb.com

  17. #17
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Sais pas comment t'as fait parce que moi aussi je voulais le faire mais c'est en grisé.
    Euh j'ai retrouvé un batch de 2016 sur mon ordi que je suis bien incapable de comprendre, je suis assez étonné d'avoir pondu un truc du genre !
    A priori je te déconseillerais de l'utiliser tel quel, puisqu'il ne supprimerais que SKype...
    Kill AllApps.bat
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    @echo off
    :: On execute les commandes en administateur 
     
    :-------------------------------------
    REM  -->  Verification des permissions
    >nul 2>&1 "%SYSTEMROOT%\system32\cacls.exe" "%SYSTEMROOT%\system32\config\system"
     
    REM --> Erreur vous ne possedez pas les droits admin
    if '%errorlevel%' NEQ '0' (
        echo Verification des privileges administrateur
        goto UACPrompt
    ) else ( goto gotAdmin )
     
    :UACPrompt
        echo Set UAC = CreateObject^("Shell.Application"^) > "%temp%\getadmin.vbs"
        set params = %*:"="
        echo UAC.ShellExecute "%~s0", "%params%", "", "runas", 1 >> "%temp%\getadmin.vbs"
     
        "%temp%\getadmin.vbs"
        exit /B
     
    :gotAdmin
        if exist "%temp%\getadmin.vbs" ( del "%temp%\getadmin.vbs" )
        pushd "%CD%"
        CD /D "%~dp0"
    :--------------------------------------
     
    mode con: cols=80 lines=8
    title D‚sinstallation-R‚installation de Skype / Version 1.0.0 / LeNarvalo
    color 0A
    set /a maxT = 100
    :0
    for /f "usebackq" %%f in (
    	`mshta "javascript:new ActiveXObject('Scripting.FileSystemObject').GetStandardStream(1).Write(new ActiveXObject('WScript.Shell').PopUp('Voulez vous supprimer Skype?',0,'Supprimer/R‚installer Skype',35));close();"`
    		) do (
    			if "%%f"=="6" (
    				if not exist "C:\Program Files\WindowsApps" (
    					rundll32 user32.dll,MessageBeep
    					mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Les fichiers de Skype sembe d‚j… d‚sinstall‚s! Ou une nouvelle version a install‚ Skype sous un nouveau nom.', 160, '[Erreur] D‚sinstallation de Skype! [Erreur]', 0 );close()"
    					goto :4
    					)
    				rem YES
    				goto :1
    			) else if "%%f"=="7" (
    				rem NO
    				goto :3
    			) else (
    				goto :3
    			)
    		)
    set /a count = 0
    :1
    taskkill /F /IM SkypeHost.exe /T
    rem if errorlevel 1 (pause)
    TAKEOWN /f "C:\Program Files\WindowsApps"
    icacls "C:\Program Files\WindowsApps" /grant %username%:(D,WDAC)
    del "C:\Program Files\WindowsApps"
    set /a count+=1
    if %count% LSS %maxT% cls 
    echo Nombre de tentatives de suppression du logiciel Skype : %count%/%maxT%
    if not exist "C:\Program Files\WindowsApps" (
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Skype supprim‚ avec succŠs aprŠs %count% tentative(s)!', 10, 'D‚sinstallation de Skype!', 64 );close()"
    	goto :3
    	)
    if %count% GEQ %maxT% (
    	rundll32 user32.dll,MessageBeep
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'La d‚sinstallation de Skype a ‚chou‚e aprŠs %count% tentatives!', 160, '[Erreur] D‚sinstallation de Skype! [Erreur]', 0 );close()"
    	goto :3
    	)
    goto :1
    :3
    mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Merci d\'avoir utiliser ce logiciel. Pour tout renseignement veuillez contacter : bzh.lenarvalo@live.fr', 160, 'Merci! =)', 0 );close()"
    exit
    :4
    echo Tapez ou copiez le nouveau chemin du fichier SkypeHost.exe … supprimer.
    echo Exemple : 
    echo C:\Program Files\WindowsApps
    set /p newpath=
    TAKEOWN /f "%newpath%"
    icacls "%newpath%" /grant %username%:(D,WDAC)
    if NOT %ERRORLEVEL% EQU 0 goto :4
    del "%newpath%"
    if not exist "%newpath%" (
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Skype supprim‚ avec succŠs !', 10, 'D‚sinstallation de Skype!', 64 );close()"
    	goto :3
    	)
    if exist "%newpath%" (
    	rundll32 user32.dll,MessageBeep
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Echec de la suppression de Skype !', 10, 'D‚sinstallation de Skype!', 64 );close()"
    	goto :3
    	)
    Sinon j'ai retrouvé ça aussi :
    Kill OneDrive.bat mais faudra changer les **** par ton nom
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    @echo off
    :: On execute les commandes en administateur 
     
    :-------------------------------------
    REM  -->  Verification des permissions
    >nul 2>&1 "%SYSTEMROOT%\system32\cacls.exe" "%SYSTEMROOT%\system32\config\system"
     
    REM --> Erreur vous ne possedez pas les droits admin
    if '%errorlevel%' NEQ '0' (
        echo Verification des privileges administrateur
        goto UACPrompt
    ) else ( goto gotAdmin )
     
    :UACPrompt
        echo Set UAC = CreateObject^("Shell.Application"^) > "%temp%\getadmin.vbs"
        set params = %*:"="
        echo UAC.ShellExecute "%~s0", "%params%", "", "runas", 1 >> "%temp%\getadmin.vbs"
     
        "%temp%\getadmin.vbs"
        exit /B
     
    :gotAdmin
        if exist "%temp%\getadmin.vbs" ( del "%temp%\getadmin.vbs" )
        pushd "%CD%"
        CD /D "%~dp0"
    :--------------------------------------
     
    mode con: cols=80 lines=8
    title D‚sinstallation-R‚installation de OneDrive / Version 1.0.0 / LeNarvalo
    color 0A
    set /a maxT = 100
    :0
    for /f "usebackq" %%f in (
    	`mshta "javascript:new ActiveXObject('Scripting.FileSystemObject').GetStandardStream(1).Write(new ActiveXObject('WScript.Shell').PopUp('Voulez vous supprimer OneDrive?',0,'Supprimer/R‚installer OneDrive',35));close();"`
    		) do (
    			if "%%f"=="6" (
    				if not exist C:\Users\*****\AppData\Local\Microsoft\OneDrive (
    					rundll32 user32.dll,MessageBeep
    					mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Les fichiers de OneDrive sembe d‚j… d‚sinstall‚s!                                                      ', 160, '[Erreur] D‚sinstallation de OneDrive! [Erreur]', 0 );close()"
    					goto :0
    					)
    				rem YES
    				goto :1
    			) else if "%%f"=="7" (
    				rem NO
    				goto :2
    			) else (
    				goto :3
    			)
    		)
    set /a count = 0
    :1
    taskkill /F /IM OneDrive.exe /T
    if errorlevel 1 (pause)
    	rem timeout /t 10
    	rem exit)
    rem taskkill /F /IM RemindersServer.exe /T
    move C:\Users\*****\AppData\Local\Microsoft\OneDrive C:\Users\*****\AppData\Local\Microsoft\OneDrive_old
    set /a count+=1
    cls 
    echo Nombre de tentatives de suppression du logiciel OneDrive : %count%/%maxT%
    if not exist C:\Windows\SystemApps\Microsoft.Windows.OneDrive_cw5n1h2txyewy (
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'OneDrive supprim‚ avec succŠs aprŠs %count% tentative(s)!', 10, 'D‚sinstallation de OneDrive!', 64 );close()"
    	goto :3
    	)
    if %count% GEQ %maxT% (
    	rundll32 user32.dll,MessageBeep
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'La d‚sinstallation de OneDrive a ‚chou‚e aprŠs %count% tentatives!', 160, '[Erreur] D‚sinstallation de OneDrive! [Erreur]', 0 );close()"
    	goto :3
    	)
    goto :1
    :2
    for /f "usebackq" %%f in (
    	`mshta "javascript:new ActiveXObject('Scripting.FileSystemObject').GetStandardStream(1).Write(new ActiveXObject('WScript.Shell').PopUp('Voulez vous r‚installer OneDrive?                                                      ',160,'Supprimer/R‚installer OneDrive',36));close();"`
    		) do (
    			if "%%f"=="6" (
    				if exist C:\Users\******\AppData\Local\Microsoft\OneDrive (
    					rundll32 user32.dll,MessageBeep
    					mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Les fichiers de OneDrive sembe d‚j… install‚s!                                                         ', 160, '[Erreur] D‚sinstallation de OneDrive! [Erreur]', 0 );close()"
    					goto :3
    					)
    				rem YES
    			) else (
    				goto :3
    			)
    		)
    if exist C:\Users\****\AppData\Local\Microsoft\OneDrive (
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'OneDrive semble d‚j… install‚!                                                  ', 160, 'Installation de OneDrive', 64 );close()"
    	goto :3
    )
    move C:\Users\*****\AppData\Local\Microsoft\OneDrive_old C:\Users\*****\AppData\Local\Microsoft\OneDrive
    if errorlevel 1 (
    	rundll32 user32.dll,MessageBeep
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'L\'installation de OneDrive a ‚chou‚e!                                                  ', 160, '[Erreur] Installation de OneDrive! [Erreur]', 0 );close()"
    	exit
    	)
    if exist C:\Users\*****\AppData\Local\Microsoft\OneDrive (
    	rundll32 user32.dll,MessageBeep
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'L\'installation de OneDrive est termin‚e!                                                  ', 160, 'Installation de OneDrive!', 0 );close()"
    )
    :3
    mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Merci d\'avoir utiliser ce logiciel. Pour tout renseignement veuillez contacter : bzh.lenarvalo@live.fr', 160, 'Merci! =)', 0 );close()"
    exit
    Et ça :
    Kill Cortana.bat mais là je crois me souvenir que c'était pas la meilleur idée que j'avais eu, puisque je crois que ça avait foutu un peu la zone...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    @echo off
    :: On execute les commandes en administateur 
     
    :-------------------------------------
    REM  -->  Verification des permissions
    >nul 2>&1 "%SYSTEMROOT%\system32\cacls.exe" "%SYSTEMROOT%\system32\config\system"
     
    REM --> Erreur vous ne possedez pas les droits admin
    if '%errorlevel%' NEQ '0' (
        echo Verification des privileges administrateur
        goto UACPrompt
    ) else ( goto gotAdmin )
     
    :UACPrompt
        echo Set UAC = CreateObject^("Shell.Application"^) > "%temp%\getadmin.vbs"
        set params = %*:"="
        echo UAC.ShellExecute "%~s0", "%params%", "", "runas", 1 >> "%temp%\getadmin.vbs"
     
        "%temp%\getadmin.vbs"
        exit /B
     
    :gotAdmin
        if exist "%temp%\getadmin.vbs" ( del "%temp%\getadmin.vbs" )
        pushd "%CD%"
        CD /D "%~dp0"
    :--------------------------------------
     
    mode con: cols=80 lines=8
    title D‚sinstallation-R‚installation de Cortana / Version 1.0.0 / LeNarvalo
    color 0A
    set /a maxT = 100
    :0
    for /f "usebackq" %%f in (
    	`mshta "javascript:new ActiveXObject('Scripting.FileSystemObject').GetStandardStream(1).Write(new ActiveXObject('WScript.Shell').PopUp('Voulez vous supprimer Cortana?\nVous ne pourrez plus utiliser la fonction Rechercher sur Windows en bas … gauche de la barre de tache!',0,'Supprimer/R‚installer Cortana',35));close();"`
    		) do (
    			if "%%f"=="6" (
    				if not exist C:\Windows\SystemApps\Microsoft.Windows.Cortana_cw5n1h2txyewy (
    					rundll32 user32.dll,MessageBeep
    					mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Les fichiers de Cortana sembe d‚j… d‚sinstall‚s!                                                      ', 160, '[Erreur] D‚sinstallation de Cortana! [Erreur]', 0 );close()"
    					goto :0
    					)
    				rem YES
    				goto :1
    			) else if "%%f"=="7" (
    				rem NO
    				goto :2
    			) else (
    				goto :3
    			)
    		)
    set /a count = 0
    :1
    taskkill /F /IM SearchUI.exe /T
    if errorlevel 1 (pause)
    	rem timeout /t 10
    	rem exit)
    rem taskkill /F /IM RemindersServer.exe /T
    move C:\Windows\SystemApps\Microsoft.Windows.Cortana_cw5n1h2txyewy C:\Windows\SystemApps\oldMicrosoft.Windows.Cortana_cw5n1h2txyewy
    set /a count+=1
    cls 
    echo Nombre de tentatives de suppression du logiciel Cortana : %count%/%maxT%
    if not exist C:\Windows\SystemApps\Microsoft.Windows.Cortana_cw5n1h2txyewy (
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Cortana supprim‚ avec succŠs aprŠs %count% tentative(s)!', 10, 'D‚sinstallation de Cortana!', 64 );close()"
    	goto :3
    	)
    if %count% GEQ %maxT% (
    	rundll32 user32.dll,MessageBeep
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'La d‚sinstallation de Cortana a ‚chou‚e aprŠs %count% tentatives!', 160, '[Erreur] D‚sinstallation de Cortana! [Erreur]', 0 );close()"
    	goto :3
    	)
    goto :1
    :2
    for /f "usebackq" %%f in (
    	`mshta "javascript:new ActiveXObject('Scripting.FileSystemObject').GetStandardStream(1).Write(new ActiveXObject('WScript.Shell').PopUp('Voulez vous r‚installer Cortana?                                                      ',160,'Supprimer/R‚installer Cortana',36));close();"`
    		) do (
    			if "%%f"=="6" (
    				if exist C:\Windows\SystemApps\Microsoft.Windows.Cortana_cw5n1h2txyewy (
    					rundll32 user32.dll,MessageBeep
    					mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Les fichiers de Cortana sembe d‚j… install‚s!                                                         ', 160, '[Erreur] D‚sinstallation de Cortana! [Erreur]', 0 );close()"
    					goto :3
    					)
    				rem YES
    			) else (
    				goto :3
    			)
    		)
    if exist C:\Windows\SystemApps\Microsoft.Windows.Cortana_cw5n1h2txyewy (
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Cortana semble d‚j… install‚!                                                  ', 160, 'Installation de Cortana', 64 );close()"
    	goto :3
    )
    move C:\Windows\SystemApps\oldMicrosoft.Windows.Cortana_cw5n1h2txyewy C:\Windows\SystemApps\Microsoft.Windows.Cortana_cw5n1h2txyewy
    if errorlevel 1 (
    	rundll32 user32.dll,MessageBeep
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'L\'installation de Cortana a ‚chou‚e!                                                  ', 160, '[Erreur] Installation de Cortana! [Erreur]', 0 );close()"
    	exit
    	)
    if exist C:\Windows\SystemApps\Microsoft.Windows.Cortana_cw5n1h2txyewy (
    	rundll32 user32.dll,MessageBeep
    	mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'L\'installation de Cortana est termin‚e!                                                  ', 160, 'Installation de Cortana!', 0 );close()"
    )
    :3
    mshta "javascript:var sh=new ActiveXObject( 'WScript.Shell' ); sh.Popup( 'Merci d\'avoir utiliser ce logiciel. Pour tout renseignement veuillez contacter : bzh.lenarvalo@live.fr', 160, 'Merci! =)', 0 );close()"
    exit

Discussions similaires

  1. [FAQ] Copier du texte dans le presse papier (Clipboard)
    Par ABOAT dans le forum Vos Contributions VBScript
    Réponses: 1
    Dernier message: 30/05/2018, 14h20
  2. fonction:copier dans le presse papier
    Par marie2006 dans le forum InfoPath
    Réponses: 3
    Dernier message: 21/10/2008, 11h10
  3. Bouton pour copier dans le presse-papier chez le client
    Par kuja2053 dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 29/08/2007, 17h01
  4. Bouton copier dans le presse-papier
    Par beru333 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 1
    Dernier message: 02/08/2007, 17h28
  5. Copier dans le presse-papier
    Par Raphs dans le forum Access
    Réponses: 4
    Dernier message: 08/08/2006, 10h45

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo