XL 2010 extraire des mots en gras

carber

XLDnaute Nouveau
Bonjour j'ai un fichier qui me permet extraire des mots en gras le souci que je n'arrive pas a mettre chaque mot dans une cellule

par exemple dans une phrase j'ai deux mot en gras ou plus alors quand j’exécute le bouton il me colle les mot qui sont en gras je souhaite les mettre chaque mot dans une cellule

svp
cordialement
 

Pièces jointes

  • test-extraction-texte-en-gras.xlsm
    19.5 KB · Affichages: 12

patricktoulon

XLDnaute Barbatruc
re
Bonjour @sylvanu 🤣 🤣
une petite correction tout de meme (il fallait bien que j'en fasse une hein !!)

comme parfois l'espace devant ou après est en bold aussi il arrive parfois que l'on est en colonne 1 ou dernière du résultat un espace
donc
la ligne corrigée
mots = Split(Trim(chainebolds(a).innertext))

je n'ai pas dimé toute les variables aussi je vous laisse deviner de quel type elle doivent etre pour les déclarer
et voilà ;)
 

sylvanu

XLDnaute Barbatruc
Supporter XLD
Re,
Alors, just for the fun.
Si toute la cellule est en gras, alors il n'y a aucune remontée.( ligne 2 )
Si toute la cellule est en gras, sauf un mot alors la remontée est correcte. (ligne 3 ou 4 )

1632573821773.png


"Just for the fun" car c'est une situation qu'il m'étonnerait que Carber rencontre. :)
 

Pièces jointes

  • 1632573636199.png
    1632573636199.png
    3.3 KB · Affichages: 18
  • 1632573744238.png
    1632573744238.png
    4 KB · Affichages: 17
  • 1632573831267.png
    1632573831267.png
    5.9 KB · Affichages: 18

mapomme

XLDnaute Barbatruc
Supporter XLD
Bonjour à tous :),

Bon puisque chacun y va de sa petite version et qu'ici il fait gris et qu'il pleut, ma pomme se fend aussi de sa p'tite version. Avec une variante:
  • Les mots consécutifs en gras sont considérés comme une seule expression
  • on considère (ce qui semble être le cas) que si la 1ère lettre d'un mot est en gras alors le mot est en gras
C'est assez rapide. Sur ma bécane, pour 800 lignes => autour de 3 s.:):)
 

Pièces jointes

  • carber- extractiontexte-en-gras- v1.xlsm
    34.7 KB · Affichages: 6

mapomme

XLDnaute Barbatruc
Supporter XLD
Bonjour @patricktoulon :)
et ben dis donc je t'aurais attendu toi t'en a mis du temps
Je suis beaucoup moins présent sur XLD depuis quelques temps. J'ai vu par hasard que ça "frétillait" sur ce fil, j'ai donc un peu codé pour ne pas trop perdre la main.

22.68 secondes pour le model de @mapomme
Tu utilises un Amstrad ou un Commodore ? De quelle année ?
Résultats très étranges.

et "bonne humeur" sont deux mots
J'ai bien précisé que c'est une variante. Dans l'exemple du demandeur, les mots en gras semblent être des états ou des sentiments.
"Bonne" n'en est pas un, "humeur" non plus mais "bonne humeur" l'est... Et je le suis 😊
 
Dernière édition:

patricktoulon

XLDnaute Barbatruc
ben non j'utilise un pc normal
j'ai essayé ca aussi mais je met encore plus de 22 secondes
VB:
Sub Entrer_Mots_Gras()
    Dim T, cel As Range, tb
    T = Timer
    Application.ScreenUpdating = False
    [B1].Resize(Rows.Count, 6).ClearContents
    With ActiveSheet.UsedRange
        For Each cel In .Cells
            tb = Mots_Gras(cel)
            cel.Offset(, 1).Resize(, UBound(tb)) = tb
        Next
    End With
    MsgBox "Durée " & Format(Timer - T, "0.00 \sec")
End Sub
Sub testInstrdoloop()
     Mots_Gras$ ([A3])
End Sub
Function Mots_Gras(c As Range)
    Dim x$, s, I%, n%, pos&, z&, s2
    x = c.Value & " "
    s = Split(x)
     ReDim s2(1 To UBound(s))
    If UBound(s) = 0 Then Exit Function
    pos = 1
    For I = 0 To UBound(s)
        z = InStr(pos, c.Value, s(I))
         If c.Characters(z, 1).Font.Bold = True Then n = n + 1: s2(n) = s(I):
        pos = pos + Len(s(I))
    Next
     Mots_Gras = s2
End Function
 

patricktoulon

XLDnaute Barbatruc
pour vous donner une idée de mon etonnement je viens de tester un tableau global en restitution globale
c'est a dire que la fonction renvoie le tableau de toutes les ligne d'un coup
et surprise c'est kif kif a 1 seconde près j'ai le même temps 23,xx secondes
autrement sur mon install je travaille casiment a la meme vitesse avec un range qu'avec une variable tableau

j'avoue je suis décontenancé et agacé

si vous voulez bien tester
VB:
Option Explicit

Sub Entrer_Mots_Gras()
    Dim T, tb, Rng As Range
    T = Timer
    [B1].Resize(Rows.Count, 150).ClearContents
    Set Rng = ActiveSheet.UsedRange
    tb = Mots_Gras(Rng)
    Rng.Offset(, 1).Resize(, UBound(tb)) = tb


    MsgBox "Durée " & Format(Timer - T, "0.00 \sec")
End Sub


Function Mots_Gras(Rng As Range)
    Dim x, I%, n%, pos&, z&, a&, tbl2
    ReDim tbl2(1 To Rng.Rows.Count, 20)
    For I = 1 To UBound(tbl2)
        x = Split(Rng.Cells(I, 1).Value)
        pos = 1
        n = 0
        For a = 0 To UBound(x)
            z = InStr(pos, Rng.Cells(I, 1), x(a))
            If Rng.Cells(I, 1).Characters(z, 1).Font.Bold = True Then n = n + 1: tbl2(I, n) = x(a)
            pos = pos + Len(x(a))
        Next
    Next
    Mots_Gras = tbl2
End Function
je vais faire un dernier test (je soupconne un truc ) et déjà remarqué et je reviens
 

Discussions similaires

Statistiques des forums

Discussions
311 724
Messages
2 081 938
Membres
101 844
dernier inscrit
pktla