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 :

accéder au n ième caractère d'une string


Sujet :

Python

  1. #1
    Membre confirmé Avatar de awesomeman
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2015
    Messages
    166
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2015
    Messages : 166
    Par défaut accéder au n ième caractère d'une string
    Bonjour,

    Tout est dit dans le titre je chercher à accéder au n ième caractère d'une string en python pour pouvoir le modifier (comme faire str[2] = 'e' en c) . J'ai trouvé comment afficher mais pour modifier je trouve tout sauf ce que je veux .
    Ca m'étonnerais que ca n'existe pas en python vu la puissance de langage .

    Merci pour votre aide !

  2. #2
    Membre chevronné
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2012
    Messages
    321
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Santé

    Informations forums :
    Inscription : Mai 2012
    Messages : 321
    Par défaut
    Bonjour,

    pour acceder au nieme indice d'une chaine, si var est la variable :

    var[n] = "d"
    les slices fonctionnent comme ceci
    var[n:m] (avec n et m les indices de debut et de fin)

  3. #3
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 756
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 756
    Par défaut
    Salut,

    Citation Envoyé par awesomeman Voir le message
    Tout est dit dans le titre je chercher à accéder au n ième caractère d'une string en python pour pouvoir le modifier (comme faire str[2] = 'e' en c) . J'ai trouvé comment afficher mais pour modifier je trouve tout sauf ce que je veux .
    Avec Python les objets de type str sont "immutables".
    On peut accéder au n-ième élément via s[n] mais pas le modifier.
    Et çà ne pose pas de problème de faire avec.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  4. #4
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    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 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    On peut accéder au ième caractère d'une chaine pour le lire mais pas pour le modifier! A chaque fois qu'une chaine doit être modifiée, elle est en fait recrée en mémoire à un autre emplacement.

    Si on essaie quand même s[2]="9", on a une erreur: "TypeError: 'str' object does not support item assignment".

    Pour modifier le caractère d'indice 2:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    x = "0123456"
    y = x[:2] + "9" + x[3:]
    print(y)
    '0193456'
    Cette limitation apparente a des avantages par ailleurs pour la gestion de la mémoire: 2 variables de même valeur peuvent pointer sur la même zone mémoire avec un compteur de référence=2. Si l'une de ces variables change de valeur, le compteur de référence est décrémenté. Et si la 2ème variable change aussi de valeur, le compteur de référence devient nul et la zone mémoire correspondante est prise en compte par le "ramasse miette" pour être replacée dans la zone mémoire libre afin d'être réutilisée.

  5. #5
    Membre confirmé Avatar de awesomeman
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2015
    Messages
    166
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2015
    Messages : 166
    Par défaut
    Merci, c'est exactement ce que je voulais . Je trouve dommage que ca soit pas plus simple comme en c . En tout cas merci tyrtamos ton code est ce que je cherchais .

  6. #6
    bm
    bm est déconnecté
    Membre extrêmement actif

    Homme Profil pro
    Freelance
    Inscrit en
    Octobre 2002
    Messages
    874
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Drôme (Rhône Alpes)

    Informations professionnelles :
    Activité : Freelance
    Secteur : Tourisme - Loisirs

    Informations forums :
    Inscription : Octobre 2002
    Messages : 874
    Billets dans le blog
    6
    Par défaut
    C'est comparable avec replace :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    my_text = 'Hello everyone. Say "Hello" to me!'
    print my_text.replace('Hello', 'Goodbye')

  7. #7
    Membre confirmé Avatar de awesomeman
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2015
    Messages
    166
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2015
    Messages : 166
    Par défaut
    Pas vraiment puisque je ne cherche pas à remplacer un caractère en particulier dans la string mais plutôt à remplacer le caractère à une certaine position .

  8. #8
    Membre chevronné
    Homme Profil pro
    Développeur banc de test
    Inscrit en
    Mai 2014
    Messages
    199
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur banc de test
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Mai 2014
    Messages : 199
    Par défaut
    Je pense que la similitude que bm relatait était sur le fait que la méthode replace ne modifiait pas le contenu/instance str en cours mais renvoyait le texte modifié, ce qui implique de réaffecter la variable si on souhaite faire un remplacement de texte.

    texte_new = texte.replace("a", "b")
    assert texte != texte_new

    Pour ce qui est de la simplification de la syntaxe, il est possible de modifier le contenu (mutable) sur le type bytearray :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    texte = bytearray("0123456789".encode('utf-8'))
    texte[0] += 1
    print(texte.decode())
    1123456789
    PEP 3137 -- Immutable Bytes and Mutable Buffer

    Citation Envoyé par PEP 3137
    bytes is an immutable array of bytes (PyString)
    bytearray is a mutable array of bytes (PyBytes)
    memoryview is a bytes view on another object (PyMemory)


    (...)


    Slicing

    Slicing a bytes object returns a bytes object. Slicing a bytearray object returns a bytearray object.

    Slice assignment to a bytearray object accepts anything that implements the PEP 3118 buffer API, or an iterable of integers in range(256).

    Indexing

    Indexing bytes and bytearray returns small ints (like the bytes type in 3.0a1, and like lists or array.array('B')).

    Assignment to an item of a bytearray object accepts an int in range(256). (To assign from a bytes sequence, use a slice assignment.)

  9. #9
    Membre confirmé Avatar de awesomeman
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2015
    Messages
    166
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2015
    Messages : 166
    Par défaut
    Citation Envoyé par YCL-1 Voir le message
    Pour ce qui est de la simplification de la syntaxe, il est possible de modifier le contenu (mutable) sur le type bytearray :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    texte = bytearray("0123456789".encode('utf-8'))
    texte[0] += 1
    print(texte.decode())
    1123456789
    l'incrémentation que tu fais ici s'applique à tout caractère ASCII ?

    par exemple si je fais ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    texte = bytearray("abcdef".encode('utf-8'))
    texte[0] += 1
    print(texte.decode())
    bbcdef
    c'est correct ?

  10. #10
    Membre chevronné
    Homme Profil pro
    Développeur banc de test
    Inscrit en
    Mai 2014
    Messages
    199
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur banc de test
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Mai 2014
    Messages : 199
    Par défaut
    Pour ton exemple oui ça marche.

    Tout dépend de l'encoding, l'unicode et l'UTF-8 utilisent la même table que l'ASCII de 0 à 127.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    assert list(map(lambda c: c.decode('ascii'), [bytes([i, ]) for i in range(128)])) == list(map(lambda c: c.decode('utf-8'), [bytes([i, ]) for i in range(128)]))
    Il est donc facile d'incrémenter 0x30 qui est "0" en ASCII pour donner "1". Il y a quelques repères faciles à retenir en hexadécimal comme "A" à la position 0x41 et "a" à 0x61.

    C'est la programmation sur µC qui m'a fait retenir la table ASCII par cœur.

    Mais si tu souhaites traduire une table des caractères il sera plus facile de maîtriser la méthode str.translate().

    Voir ce message pour l'usage: http://www.developpez.net/forums/d15...e/#post8560538

  11. #11
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 756
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 756
    Par défaut
    Salut,

    Citation Envoyé par YCL-1 Voir le message
    Pour ce qui est de la simplification de la syntaxe, il est possible de modifier le contenu (mutable) sur le type bytearray :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    texte = bytearray("0123456789".encode('utf-8'))
    texte[0] += 1
    print(texte.decode())
    1123456789
    PEP 3137 -- Immutable Bytes and Mutable Buffer
    Certes mais utf-8 peut encoder un caractère sur 2/3 ou 4 bytes: par facile se savoir quel sera l'index du "byte" à changer après un .encode('utf-8').
    Mais bytearray fonctionnera très bien avec des encoding 1 pour 1 comme ASCII ou latin-1.

    Citation Envoyé par awesomeman Voir le message
    l'incrémentation que tu fais ici s'applique à tout caractère ASCII ?

    par exemple si je fais ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    texte = bytearray("abcdef".encode('utf-8'))
    texte[0] += 1
    print(texte.decode())
    bbcdef
    c'est correct ?
    bytearray est un tableau d'entiers dans 0..255. C'est ce qui permet le += 1. Pour travailler avec des "caractères", on peut écrire:

    Mais on est limité aux littéraux ASCII.

    C'est quand même pas si compliqué d'écrire une fonction à partir des instructions données par Tyrtamos:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    >>> def replace(s, n, ch):
    ...     return s[:n] + ch + s[n+1:]
    ...
    >>> replace('abcd', 2, 'X')
    'abXd'
    >>>
    transformer un string en bytearray puis en string, c'est pareil que de fabriquer une nouvelle chaîne de caractères: autant le faire le plus simplement possible.
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [RegEx] Remplacer des caractères dans une string
    Par jexl dans le forum Langage
    Réponses: 2
    Dernier message: 15/03/2007, 22h26
  2. [deb]Accéder aux caractères d'une string
    Par Raideman dans le forum C++
    Réponses: 4
    Dernier message: 22/08/2006, 15h28
  3. Connaitre le jeu de caractères d'une String ?
    Par dedz dans le forum Langage
    Réponses: 7
    Dernier message: 29/06/2006, 14h15
  4. Réponses: 7
    Dernier message: 29/05/2006, 14h46
  5. Réponses: 6
    Dernier message: 24/07/2003, 12h39

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