Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-09-2002, 19:25   #1
kanizsa
Member
 
Iscritto dal: Nov 2001
Messaggi: 79
VBA: come si shifta meglio da una cella all'altra?

In un foglio Excel ho la necessita' che venga effettuata la seguente procedura:

- AL VARIARE DI "A" (e' un dato dinamico che Excel riceve in DDE)

AZIONE

- CAMBIA LA CELLA "C" (cella Excel vuota, viene completata dal codice VBA)

IMMETTENDO IL VALORE CONTENUTO IN CELLA "B" (pure essa e' un dato dinamico, che Excel riceve in DDE)

Per fare questo "ultrabanale" passaggio di un solo dato da una cella all'altra in Excel, nel tempo ho adottato via via le seguenti soluzioni che si sono rivelate purtroppo portatrici di inconvenienti vari:

1) procedure senza VBA con la tecnica dei test condizionali basati sui riferimenti circolari

PRO Funziona veloce
CONTRO Non e' un bel esempio di programmazione ricorrere ai riferiemnti circolari


2) procedure con textbox

PRO Funziona, anche se abbastanza lenta
CONTRO Occorre immettere degli oggetti come le caselle di testo sul foglio Excel. Poco elegante

3) Procedura con la Worksheet Calculate.

PRO Funziona velocemente e non richiede oggetti sul foglio
CONTRO: e' una funzione delicata, basta mettere la funzione "data" sul foglio od altre ed il Calculate inevitabilmente parte in azione, mandando in loop il foglio Excel. E' quello che succede spesso quando si effettuano dei passaggi di task con Control-Tab ed il prg. Excel diventa bianco (cioe’ bloccato).
Talvolta devo aspettare anche un minuto prima di poter accedere al task di Excel

Chiedo cortesemente:
conoscete mica altre procedure o funzioni in ambiente Excel o VBA per svolgere questo banalissimo scopo di passare valori da una cella dinamica all'altra statica? (es. worksheet selection ? worksheet change, funzioni preparate dall’utente, altre ancora ?)
kanizsa è offline   Rispondi citando il messaggio o parte di esso
Old 26-09-2002, 19:36   #2
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
If Cells(1, 3) = "" Then Cells(1, 3) = Cells(1, 1)

io uso sempre questo banale metodo, non so se ho capito quello che intendevi
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 26-09-2002, 23:16   #3
kanizsa
Member
 
Iscritto dal: Nov 2001
Messaggi: 79
Quote:
Originariamente inviato da misterx
[b]If Cells(1, 3) = "" Then Cells(1, 3) = Cells(1, 1)

io uso sempre questo banale metodo, non so se ho capito quello che intendevi
Ok per il codice che hai scritto, ma dove lo incorpori ? In Wchange o in W calculate ?

L’uso dell'evento Worksheet Change potrebbe in effetti essere alternativo all’evento W.s Calculate che ho specificato sopra e che attualmente uso per raggiungere gli stessi risultati, ma con poca affidabilita' e robustezza.

La differenza teorica tra i due approcci Change e calculate non la conosco, quella pratica si.
Su un foglio Excel unico WS Change funziona.
Pero’ dal momento che io uso due fogli diversi (uno, Foglio1, per il datafeed DDE ed un altro, Foglio 2, che richiama con un riferimento la cella contenuta in Foglio 1) in questo caso non funziona piu’, sebbene la guida VBA reciti che sia possibile linkare il secondo foglio Excel ad un collegamento esterno.

Evidentemente il collegamento esterno non e’ inteso essere il foglio 1

Ecco le istruzioni della guida
Private Sub oggetto_SheetChange(ByVal Sh As Object, ByVal Source As Range)
Si verifica quando celle di un qualsiasi foglio di lavoro sono modificate dall'utente o mediante un collegamento esterno.
kanizsa è offline   Rispondi citando il messaggio o parte di esso
Old 28-09-2002, 10:26   #4
kanizsa
Member
 
Iscritto dal: Nov 2001
Messaggi: 79
In pratica, riformulo la domanda in senso pratico, cosi' forse si capisce meglio.

Data la macro VBA

Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Row = 1 And Target.Column = 2 Then 'se condizione
A=B 'azione
End If
If Target.Row = 1 And Target.Column = 3 Then
A=C
End If
If Target.Row = 1 And Target.Column = 4 Then
A=D
End If
If Target.Row = 1 And Target.Column = 5 Then
A=E
End If
‘(Etcetera, ad libitum )
End Sub

secondo voi esistono dei sistemi piu' efficienti ed/o eleganti per implementare l'evento Change del modello sopra che agisce su una selezione contigua di intervalli di celle ?
Esempio usando dei test condizionali, cicli, loop, etc. ?
kanizsa è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
Virtua Fighter è tornato e non &e...
Il ritorno di Fumito Ueda, autore di Sha...
Cooler Master svela GPU Shield, la nuova...
Samsung Galaxy S27 Pro: sarà lui ...
Così Google ha ottimizzato Chrome...
Xiaomi non cambia idea: il display poste...
LG presenta in Italia le gamme TV Micro ...
Sette anni dopo l'annuncio, The Wolf Amo...
'Non avrete aumenti': la decisione shock...
TIM lancia il Pass Mondiali DAZN: 104 pa...
Tesla Roadster, promessa o miraggio? La ...
Mark Hamilton, la tavola periodica del m...
Hanger 13 annuncia Uomo d'Onore: espansi...
La battaglia delle HBM4 entra nel vivo: ...
Dopo 12 anni torna Alien: Isolation. Ecc...
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: 22:38.


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