Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Romo, il robot aspirapolvere tutto trasparente
DJI Romo, il robot aspirapolvere tutto trasparente
Anche DJI entra nel panorama delle aziende che propongono una soluzione per la pulizia di casa, facendo leva sulla propria esperienza legata alla mappatura degli ambienti e all'evitamento di ostacoli maturata nel mondo dei droni. Romo è un robot preciso ed efficace, dal design decisamente originale e unico ma che richiede per questo un costo d'acquisto molto elevato
DJI Osmo Nano: la piccola fotocamera alla prova sul campo
DJI Osmo Nano: la piccola fotocamera alla prova sul campo
La nuova fotocamera compatta DJI spicca per l'abbinamento ideale tra le dimensioni ridotte e la qualità d'immagine. Può essere installata in punti di ripresa difficilmente utilizzabili con le tipiche action camera, grazie ad una struttura modulare con modulo ripresa e base con schermo che possono essere scollegati tra di loro. Un prodotto ideale per chi fa riprese sportive, da avere sempre tra le mani
FUJIFILM X-T30 III, la nuova mirrorless compatta
FUJIFILM X-T30 III, la nuova mirrorless compatta
FUJIFILM X-T30 III è la nuvoa fotocamera mirrorless pensata per chi si avvicina alla fotografia e ricerca una soluzione leggera e compatta, da avere sempre a disposizione ma che non porti a rinunce quanto a controllo dell'immagine.
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


DJI Romo, il robot aspirapolvere tutto trasparente DJI Romo, il robot aspirapolvere tutto trasparen...
DJI Osmo Nano: la piccola fotocamera alla prova sul campo DJI Osmo Nano: la piccola fotocamera alla prova ...
FUJIFILM X-T30 III, la nuova mirrorless compatta FUJIFILM X-T30 III, la nuova mirrorless compatta
Oracle AI World 2025: l'IA cambia tutto, a partire dai dati Oracle AI World 2025: l'IA cambia tutto, a parti...
Micron e millisecondi: la piattaforma ServiceNow guida l'infrastruttura IT di Aston Martin F1 Micron e millisecondi: la piattaforma ServiceNow...
iOS 26.1: è in arrivo il backup a...
Xbox Next Gen, non chiamatela console: s...
.Next On Tour Italia: innovazione, sempl...
PS Plus novembre: svelato in anticipo il...
'Gli elettroni sono il nuovo petrolio': ...
Amazon freme, non ce la fa ad aspettare ...
Hisense HS2100 240W a soli 75,90€ su Ama...
Addio personal trainer: il coach via AI ...
Creative reinventa il mito Sound Blaster...
Liquid Glass impatta sulla batteria degl...
Grokipedia di Elon Musk accusata di copi...
Google Pixel 9a scende a 382€ su Amazon:...
A 149€ il tablet senza compromessi: 1920...
11 accessori auto utilissimi in offerta ...
C'è un team italiano dietro gli a...
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: 12:29.


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