Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
NUC 15 Pro e NUC 15 Pro+ sono i due nuovi mini-PC di casa ASUS pensati per uffici e piccole medie imprese. Compatti, potenti e pieni di porte per la massima flessibilità, le due proposte rispondono in pieno alle esigenze attuali e future grazie a una CPU con grafica integrata, accompagnata da una NPU per la gestione di alcuni compiti AI in locale.
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Dal palco di Proofpoint Protect 2025 emerge la strategia per estendere la protezione dagli utenti agli agenti IA con il lancio di Satori Agents, nuove soluzioni di governance dei dati e partnership rafforzate che ridisegnano il panorama della cybersecurity
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-11-2009, 15:04   #1
romeombo
Bannato
 
Iscritto dal: Nov 2009
Messaggi: 2
[VBA macro] Problema con .Find

Ciao a tutti,
ho un problema con la ricerca in un foglio excel attraverso una macro.
Mi spiego meglio :

Ho 2 campi, colonne (A,B)
La colonna A possiede 332 righe
La colonna B possiede 895 righe

Voglio, attraverso macro, per tutti i valori contenuti nella colonna A cercare tutte quelle righe di B che contengono un valore simile ad A e posizionare i vari valori trovati in una terza colonna, la C separati dal carattere ; punto e virgola.

Ad esempio
Codice:
A                   B                         C
pippo                pippo_1                pippo_1;pippo_2;pippo_3
paperino             pippo_2                paperino_1;paperino_2;paperino_3;
pluto                pippo_3                pluto_1;pluto_2
                     paperino_1
                     paperino_2
                     paperino_3                     
                     pluto_1
                     pluto_2
ovvero nella colonna B , il valore pippo di A occorre 3 volte e quindi tutte e tre le occorrenze dovrebbero apparire in C seguita da un punto e virgola.
Stessa cosa per paperino etc....

A tale scopo ho scritto questa macro :
Codice:
Public Function FindAllStrings(ByVal strSearchString As String)
    With ActiveSheet.Range("B1:B895")
       Set c = .Find(strSearchString, LookIn:=xlValues)
       If Not c Is Nothing Then
        Valore = c.Value
        first = c.Address
        firstRow = c.Row
        firstCol = c.Column
            Do
                Valore = Valore & ";" & c.Value
                Set c = .FindNext(c)
            Loop While c Is Nothing And c.Address <> first
             ActiveSheet.Cells(firstRow, firstCol + 1).Value = Valore
        End If
    End With
End Function
Sub Trova_e_Copia()
'
' Trova_e_Copia Macro
'
For i = 1 To 332
    FindAllStrings (Range("A" & i).Value)
Next i
End Sub
Il problema è che eseguendola non mi trova tutti i campi ma solo alcuni di essi a volte raddoppiandoli. ad esempio in C avrò qualcosa tipo

C
pippo_2;pippo_2
paperino_1;paperino_1;
pluto_1;pluto_2

Stranezza è che provando con una cosa simile

Codice:
With ActiveSheet.Range("B1:B895")
       Set c = .Find("pippo", LookIn:=xlValues)
       MsgBox(c.Value)
End With
appare il messaggio con pippo_2 e non con pippo_1.
Invece se eseguo una ricerca tradizionale usando lo strumento messo a disposizione da Excel stesso, nessun problema, find mi trova la prima occorrenza, usando next passa alla seconda occorrenza, usando next all'eventuale terza occorrenza, senza problemi
mi vien da pensare che non funzioni a dovere la funzione .find
Grazie
romeombo è offline   Rispondi citando il messaggio o parte di esso
Old 16-11-2009, 18:24   #2
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da romeombo Guarda i messaggi
Ciao a tutti,
ho un problema con la ricerca in un foglio excel attraverso una macro.
Mi spiego meglio :

Ho 2 campi, colonne (A,B)
La colonna A possiede 332 righe
La colonna B possiede 895 righe

Voglio, attraverso macro, per tutti i valori contenuti nella colonna A cercare tutte quelle righe di B che contengono un valore simile ad A e posizionare i vari valori trovati in una terza colonna, la C separati dal carattere ; punto e virgola.

Ad esempio
Codice:
A                   B                         C
pippo                pippo_1                pippo_1;pippo_2;pippo_3
paperino             pippo_2                paperino_1;paperino_2;paperino_3;
pluto                pippo_3                pluto_1;pluto_2
                     paperino_1
                     paperino_2
                     paperino_3                     
                     pluto_1
                     pluto_2
ovvero nella colonna B , il valore pippo di A occorre 3 volte e quindi tutte e tre le occorrenze dovrebbero apparire in C seguita da un punto e virgola.
Stessa cosa per paperino etc....
Codice:
    Dim a As Long
    a = 1
    Dim b As Long
    b = 1
    Dim c As Long
    c = 1
    Dim s As String
    Do
        If Range("A" & a).Text = "" Then Exit Do
        s = ""
        b = 1
        Do
            If Range("B" & b).Text = "" Then Exit Do
            If Not Range("B" & b).Find(Range("A" & a).Text) Is Nothing Then
                s = s & Range("B" & b).Text & ";"
            End If
            b = b + 1
        Loop
        If s <> "" Then
            Range("C" & c).FormulaR1C1 = s
            c = c + 1
        End If
        a = a + 1
    Loop
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondo...
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint Cybersecurity: email, utenti e agenti IA, la nuo...
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Spotify rivoluziona la sua guida: Daniel...
Sora 2: la seconda generazione del model...
Nuovo obiettivo FE 100mm F2.8 Macro GM O...
Steelseries Arctis Nova Elite: le prime ...
30 anni di PlayStation da indossare: arr...
Amazon lancia gli Echo più potent...
Amazon rinnova la gamma Fire TV: ecco le...
Ring lancia le sue prime videocamere con...
Blink amplia la gamma di videocamere di ...
Jaguar Land Rover riprende (gradualmente...
HONOR inaugura il primo ALPHA Flagship S...
Yamaha: ecco il brevetto del 'finto moto...
'Console obsoleta e utenti ingannati': u...
Stop al ransomware su Google Drive, graz...
L'IA è la nuova interfaccia utent...
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: 00:19.


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