Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-04-2006, 12:40   #1
OrcaAssassina
Senior Member
 
Iscritto dal: Feb 2003
Messaggi: 2817
[VB6] Operazioni con le date

Inserendo una data di un pagamento, mi deve scrivere vicino la sua scadenza.

Tale scadenza può essere:
Mensile
Trimetrale
Semestrale
Annuale

La scelta di questi periodi li ho messi in una combo

Quindi mettendo la data di pagamentom scegliendo il metodo di pagamento, inteso come scadenza, mi deve dare la data di scadenza


Come faccio a maggiorae tale data di:
un mese
oppure
di 3 mesi
oppure
di 6 mesi
oppure
di un anno

Ciao e grazieeeeeee
__________________
AMD 3700x --- ASUS X570 CROSSHEAR VIII HERO --- 4x 8GB Corsair Vengeance RGB PRO 3600 MHz --- SSD: Samsung 980Pro 1TBb --- EVGA RTX 2070 SUPER
OrcaAssassina è offline   Rispondi citando il messaggio o parte di esso
Old 08-04-2006, 13:45   #2
Furla
Senior Member
 
Iscritto dal: Feb 2004
Messaggi: 1454
non sono un esperto, ma ti consiglio di fare come ho fatto io in passato, ovvero di usare la data presa dall'orologio di sistema e convertirla in stringa per fare tutte le operazioni che vuoi.

la funzione date() restituisce la data in formato gg/mm/aaaa, quindi scrivendo

Quote:
dim data as string
data = cstr(date)
a questo punto puoi ottenere la data di una scadenza trimestrale, ad esempio, prelevando le cifre del mese, convertendole in valori, aggiungendo 3 al numero e ricollocandole nella stringa della data, sfruttando le funzioni delle stringhe (left, mid, right)

Quote:
dim scadenza as string
scadenza = left(data, 2) & "/" & cstr(val(mid(data, 4, 2)) + 3) & "/" & right(data, 4)
a questo punto il mese potrebbe avere una cifra sola (e dobbiamo aggiungere uno zero), o essere un valore maggiore di 12 (occorre passare all'anno successivo); quindi si mettono dei controlli:

Quote:
dim ok as boolean
ok = false
do while ok = false
if len(scadenza) < 10 then
scadenza = left(scadenza, 3) & "0" & right(scadenza, 6)' non so se te lo prende, forse ci vuole una variabile aggiuntiva per la stringa risultante, visto che applichi le funzioni alla stessa stringa
ok = false
else
ok = true
end if

if val(mid(scadenza, 4, 2)) > 12 then
scadenza = left(scadenza, 3) & cstr(val(mid(scadenza, 4, 2)) - 12) & cstr(val(right(scadenza, 6))+1)' non so se te lo prende, forse ci vuole una variabile aggiuntiva per la stringa risultante, visto che applichi le funzioni alla stessa stringa
ok = false
else
ok = true
end if
loop
la variabile ok serve perché può capitare che dopo aver applicato il secondo controllo vada riapplicato il primo, e solo quando nessuno dei due corregge la stringa si esce dal ciclo e la stringa è a posto.



il concetto é questo, non so se ci sono metodi più semplici. onestamente non sono ferratissimo di vb6, quindi non ti so dire se è possibile applicare funzioni come il mid ad una stringa in cui collochiamo direttamente il risultato della funzione. comunque è un problema facilmente risolvibile con l'uso di una variabile di supporto.

spero di esserti stato di aiuto, scusami ma non ho tempo di ricontrollare... se hai dei problemi con il codice che ti ho postato fammi sapere che lo rivediamo
Furla è offline   Rispondi citando il messaggio o parte di esso
Old 08-04-2006, 15:27   #3
salvuccio
Member
 
Iscritto dal: Aug 2004
Messaggi: 55
Hai guardato la funzione DateAdd() nella guida online?
Non ho sottomano VB in questo momento perciò vado a naso e potrei anche scrivere qualche fesseria, però puoi provare così:

Private Sub Combo_Click()
Select Case Combo.List(Combo.ListIndex)
Case "Mensile"
DataFinale = DateAdd("m", 1, DataIniziale)
Case "Trimestrale"
DataFinale = DateAdd("m", 3, DataIniziale)
Case "Semestrale"
DataFinale = DateAdd("m", 6, DataIniziale)
Case "Annuale"
DataFinale = DateAdd("m", 12, DataIniziale)
Case Else

End Select
End Sub

Ultima modifica di salvuccio : 08-04-2006 alle 15:31.
salvuccio è offline   Rispondi citando il messaggio o parte di esso
Old 08-04-2006, 17:33   #4
OrcaAssassina
Senior Member
 
Iscritto dal: Feb 2003
Messaggi: 2817
Quote:
Originariamente inviato da salvuccio
Hai guardato la funzione DateAdd() nella guida online?
Non ho sottomano VB in questo momento perciò vado a naso e potrei anche scrivere qualche fesseria, però puoi provare così:

Private Sub Combo_Click()
Select Case Combo.List(Combo.ListIndex)
Case "Mensile"
DataFinale = DateAdd("m", 1, DataIniziale)
Case "Trimestrale"
DataFinale = DateAdd("m", 3, DataIniziale)
Case "Semestrale"
DataFinale = DateAdd("m", 6, DataIniziale)
Case "Annuale"
DataFinale = DateAdd("m", 12, DataIniziale)
Case Else

End Select
End Sub


Perfetto funziona...alla grande

Ciao e grazieeeeeeeee
__________________
AMD 3700x --- ASUS X570 CROSSHEAR VIII HERO --- 4x 8GB Corsair Vengeance RGB PRO 3600 MHz --- SSD: Samsung 980Pro 1TBb --- EVGA RTX 2070 SUPER
OrcaAssassina è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Pokémon Rosso Fuoco e Verde Fogli...
Risparmiare con le offerte Amazon: weeke...
Gli Xiaomi 17 arrivano a fine febbraio, ...
48.000 Pa a poco più di 100€: la ...
PC più potente, meno spesa: su Amazon to...
Con 2 acquisti si ottiene il 40% di scon...
Blocco VPN in Spagna durante le partite ...
ECOVACS DEEBOT T30C OMNI GEN2 torna a 34...
Cercate uno smartphone? Ecco 7 modelli i...
Paramount non molla: Netflix è pr...
Missione Artemis II diretta verso la Lun...
Toy Story 5 arriva al cinema: è l...
Intel cambia rotta su Linux? Nuove assun...
Samsung aggiorna Bixby con One UI 8.5: p...
L'Etiopia vieta le auto a combustione: 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:10.


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