Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-04-2008, 18:37   #1
ramo102e
Member
 
Iscritto dal: Aug 2007
Messaggi: 48
[VBA] Word - Conteggio caratteri

Ciao a tutti, ho una macro VBA di Word che dovrebbe contare tutti i caratteri presenti in un documento, compresi quelli che Word stesso esclude dal conteggio, come header e footer (le note a pie' di pagine si possono facilmente includere o meno).
Il problema e' che la suddetta macro, non appena inserico nel documento una nota o un header/footer, sballa il conteggio aumentando di 4 il numero di parole e caratteri presenti.

Ecco il codice:
Codice:
Option Explicit

Sub CountAllCharacters()

Dim ostory As Object
Dim caratteri As Long, Parole As Long, CaratteriWord As Long, ParoleWord As Long, CaratteriSelezione As Long, ParoleSelezione As Long
Dim Percent As Integer
Dim RigheSelezioneArr As Integer
Dim Selezione As Range
Dim Righe As Double, CartelleSelezione As Double, RigheSelezione As Double, Cartelle As Double
Dim MessaggioSelezione As String, MessaggioDiverso As String, Messaggio As String
Dim RigheArr

For Each ostory In ActiveDocument.StoryRanges
caratteri = caratteri + ostory.ComputeStatistics(wdStatisticCharactersWithSpaces)
Parole = Parole + ostory.ComputeStatistics(wdStatisticWords)

Do While Not (ostory.NextStoryRange Is Nothing)

Set ostory = ostory.NextStoryRange
caratteri = caratteri + ostory.ComputeStatistics(wdStatisticCharactersWithSpaces)
Parole = Parole + ostory.ComputeStatistics(wdStatisticWords)

Loop
Next ostory

CaratteriWord = ActiveDocument.ComputeStatistics(Statistic:=wdStatisticCharactersWithSpaces)
ParoleWord = ActiveDocument.ComputeStatistics(Statistic:=wdStatisticWords)

Cartelle = caratteri / 1500
Cartelle = Round(Cartelle, 2)

Righe = caratteri / 55
RigheArr = -Int(-Righe)
Righe = Round(Righe, 2)

 
If Not Selection.Start = Selection.End Then
     
    CaratteriSelezione = Selection.Range.ComputeStatistics(Statistic:=wdStatisticCharactersWithSpaces)
    ParoleSelezione = Selection.Range.ComputeStatistics(Statistic:=wdStatisticWords)

    CartelleSelezione = CaratteriSelezione / 1500
    CartelleSelezione = Round(CartelleSelezione, 2)
 
    RigheSelezione = CaratteriSelezione / 55
    RigheSelezioneArr = -Int(-RigheSelezione)
    RigheSelezione = Round(RigheSelezione, 2)

    Percent = CaratteriSelezione * 100 / caratteri

    MessaggioSelezione = "Conteggio nella selezione:" & vbCr _
         & "  parole:                             " & ParoleSelezione & vbCr _
         & "  caratteri spazi inclusi:      " & CaratteriSelezione & vbCr _
         & "  cartelle:                           " & CartelleSelezione & vbCr _
         & "  righe:                               " & RigheSelezioneArr & " (" & RigheSelezione & ")" & vbCr & vbCr _
         & "La selezione corrisponde al " & Percent & "% del testo totale." & vbCr _
         & "_____________________________________________________" & vbCr & vbCr

End If

 
If caratteri <> CaratteriWord Then

    MessaggioDiverso = "Conteggio di Word:" & vbCr _
         & "  parole:                             " & ParoleWord & vbCr _
         & "  caratteri spazi inclusi:      " & CaratteriWord & vbCr _
         & "_____________________________________________________" & vbCr & vbCr

End If

 
Messaggio = "Conteggio comprensivo di cornici di testo, pié di pagina, note, ecc." & vbCr _
         & "_____________________________________________________" & vbCr & vbCr _
         & MessaggioSelezione _
         & MessaggioDiverso _
         & "Conteggio completo:" & vbCr _
         & "  parole:                             " & Parole & vbCr _
         & "  caratteri spazi inclusi:      " & caratteri & vbCr _
         & "  cartelle:                           " & Cartelle & vbCr _
         & "  righe:                               " & RigheArr & " (" & Righe & ")" & vbCr _
         & "_____________________________________________________" & vbCr & vbCr _
         & "                                 Buon lavoro!!!"

 
MsgBox Messaggio, 64

End Sub
Faccio un esempio: se aggiungo come header la parola "Intestazione" mi aspetterei di avere il risultato:
word: 1 characters: 12
Invece ottengo:
word: 5 characters: 16

Successivamente invece il conteggio dei caratteri di queste entita' avviene correttamente.
Qualcuno sa come correggerlo? Grazie!
ramo102e è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2008, 09:45   #2
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Capita, quando si copia/incolla una macro che non è farina del nostro sacco !
L' ho provata anch'io ed effettivamente aggiunge 4 solo se nell'Header del documento esiste almeno un carattere...
Perciò la cosa può essere risolta semplicemente con una piccola aggiunta in questa sezione del codice :

Codice:
...
...
    If caratteri <> CaratteriWord Then
    
        MessaggioDiverso = "Conteggio di Word:" & vbCr _
             & "  parole:                             " & ParoleWord & vbCr _
             & "  caratteri spazi inclusi:      " & CaratteriWord & vbCr _
             & "_____________________________________________________" & vbCr & vbCr
    
    End If
    
    With ActiveDocument.Sections(1).Headers(wdHeaderFooterPrimary)
        If .Range <> "" Then
            Parole = Parole - 4
            caratteri = caratteri - 4
        End If
    End With
         
    Messaggio = "Conteggio comprensivo di cornici di testo, pié di pagina, note, ecc." & vbCr _
             & "_____________________________________________________" & vbCr & vbCr _
             & MessaggioSelezione _
             & MessaggioDiverso _
             & "Conteggio completo:" & vbCr _
             & "  parole:                             " & Parole & vbCr _
             & "  caratteri spazi inclusi:      " & caratteri & vbCr _
             & "  cartelle:                           " & Cartelle & vbCr _
             & "  righe:                               " & RigheArr & " (" & Righe & ")" & vbCr _
             & "_____________________________________________________" & vbCr & vbCr _
             & "                                 Buon lavoro!!!"
    
     
    MsgBox Messaggio, 64
Prova, .
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2008, 11:51   #3
ramo102e
Member
 
Iscritto dal: Aug 2007
Messaggi: 48
In questo caso funziona se il documento presenta un header o un footer con qualcosa scritto dentro, altrimenti il conteggio viene ugualmente diminuito di quattro unita' (in un documento vuoto si ottiene parole: -4, caratteri: -4).
E' possibile evitarlo?
ramo102e è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2008, 13:57   #4
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da ramo102e Guarda i messaggi
In questo caso funziona se il documento presenta un header o un footer con qualcosa scritto dentro, altrimenti il conteggio viene ugualmente diminuito di quattro unita' (in un documento vuoto si ottiene parole: -4, caratteri: -4).
E' possibile evitarlo?
A me non succede...
Se il doc. è completamente vuoto mi da :

Conteggio completo :
Parole : 0
Caratteri spazi inclusi : 0



Sicuro di aver inserito il mio codice ( rosso ) nella posizione corretta ?
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2008, 13:59   #5
ramo102e
Member
 
Iscritto dal: Aug 2007
Messaggi: 48
In realta' ho notato che il -4 lo da' solo nel primo conteggio, dal secondo in poi funziona benissimo.
Ci sara' qualcosa da inizializzare (conta 4 caratteri e parole all'interno del loop delle "ostory"), ma dal debug non sono riuscito a capire dove li vada a prendere...
ramo102e è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2008, 14:01   #6
ramo102e
Member
 
Iscritto dal: Aug 2007
Messaggi: 48
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
A me non succede...
Se il doc. è completamente vuoto mi da :

Conteggio completo :
Parole : 0
Caratteri spazi inclusi : 0

Sicuro di aver inserito il mio codice ( rosso ) nella posizione corretta ?
Si, ho inserito nel posto giusto.
Ma funziona come ti ho detto. Magari dipende dalla versione di Office: io sto usando la 2003...
ramo102e è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2008, 14:21   #7
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da ramo102e Guarda i messaggi
Si, ho inserito nel posto giusto.
Ma funziona come ti ho detto. Magari dipende dalla versione di Office: io sto usando la 2003...
No, non dipende da quello. Anch'io ho il 2003.
Comunque sostituisci il mio precedente codice rosso con questo, e andrà bene per forza :

Codice:
    With ActiveDocument.Sections(1).Headers(wdHeaderFooterPrimary)
        If .Range <> "" Then
            Parole = Parole - 4
            caratteri = caratteri - 4
        End If
    End With
    If Parole < 0 Then Parole = 0
    If caratteri < 0 Then caratteri = 0
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2008, 14:46   #8
ramo102e
Member
 
Iscritto dal: Aug 2007
Messaggi: 48
Yes, ci avevo pensato anch'io... grazie per la soluzione!
ramo102e è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Il remake di Assassin's Creed IV: Black ...
Tutti i robot aspirapolvere in offerta s...
Amazon Haul spinge la promo di San Valen...
Offerte hardware Amazon per l'upgrade de...
iPhone 17e dovrà fare i conti con...
Offerte Amazon sugli iPhone di ultima ge...
DJI Mini 5 Pro Combo Fly More scende a 8...
Ubisoft potrebbe licenziare ancora ma se...
Samsung Galaxy S26: un leak anticipa col...
Aetherflux e Lockheed Martin insieme per...
SpaceX sta proseguendo i test della terz...
Axiom Space ha mostrato un nuovo video d...
Realme: la trasformazione in sub-brand d...
PlayStation 6 si farà attendere: ...
BWT Alpine chiude la prima tornata di pr...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 20:07.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v