Vai indietro   Scuola forum (scuo.la) - Forum di discussione per le scuole > Materie di Scuola > Informatica



Top 5 Stats
Latest Posts
Discussione    data, Ora  invio  Risposte  Visite   Forum
Vecchio Cosa causa dolore fianco destro, intorpidimento piede e nausea?  01-05, 16:31  Marcos  1  21756   Medicina
Vecchio Quanti punti di invalidità per una distorsione alla caviglia?  01-05, 13:25  Sigismondo  1  17134   Medicina
Vecchio Come vedere se 1/5 stipendio inquilino è già stato ceduto?  30-04, 15:01  Harley  1  40016   Diritto
Vecchio Come risolvere per bullone serbatoio olio motore spanato?  30-04, 11:19  Leandro  1  15027   Auto, Moto, Motori
Vecchio Come eliminare definitivamente messaggio Internet Explorer?  29-04, 17:25  Yves  1  21207   Informatica
Vecchio Come fare per calcolare l'abbondanza isotopica del 63Cu?  27-04, 18:25  Abramo  1  33220   Chimica
Vecchio Quali passaggi per tracciare diagramma potenziale/pH dello zinco?  27-04, 12:44  manuel  1  26020   Chimica
Vecchio Può il medico di famiglia chiedere soldi a paziente per incidente?  27-04, 09:05  Edith  1  24583   Medicina
Vecchio Perchè pompa dell'acqua fa uno strano rumore e non pompa più?  26-04, 09:01  Marsilio  1  27361   Idraulica
Vecchio È possibile rimuovere il vetrino del contatore dell'acqua?  24-04, 07:58  karol  1  54404   Idraulica

Rispondi
 
LinkBack Strumenti della discussione Modalità di visualizzazione
  #1 (permalink)  
Vecchio 12-24-2007, 10:34 PM
Administrator
 
Registrato dal: Jun 2007
Messaggi: 641
predefinito Ordinare celle Excel 2007 in maniera relativa in VBA

Ordinare celle Excel 2007 in maniera relativa in VBA


Salve,
con Excel 2003 ero abituato a selezionare con una macro l'intervallo di celle che volevo ordinare e poi scrivere qualcosa del genere:

Quote:
Rows("2:2").Select
Range("F2").Activate
Range(Selection, Selection.End(xlDown)).Select

Selection.Sort Key1:=Range("C1"), Order1:=xlAscending, Key2:=Range("k1") _
, Order2:=xlAscending, Header:=xlGuess, OrderCustom:=1, MatchCase:= _
False, Orientation:=xlTopToBottom, DataOption1:=xlSortNormal, DataOption2 _
:=xlSortNormal
Ora, con la versione 2007, la faccenda è un po' cambiata, e la stessa operazione viene registrata più o meno così, nonostante io la registri utilizzando i riferimenti relativi:

Quote:
Range("F2").Select
ActiveCell.Rows("1:1").EntireRow.Select
ActiveCell.Activate
Range(Selection, Selection.End(xlDown)).Select
ActiveWorkbook.Worksheets("Statistiche").Sort.SortFields.Clear
ActiveWorkbook.Worksheets("Statistiche").Sort.SortFields.Add Key:=ActiveCell. _
Offset(0, 2).Range("A1:A351"), SortOn:=xlSortOnValues, Order:=xlAscending, _
DataOption:=xlSortNormal
ActiveWorkbook.Worksheets("Statistiche").Sort.SortFields.Add Key:=ActiveCell. _
Offset(0, 10).Range("A1:A351"), SortOn:=xlSortOnValues, Order:=xlAscending, _
DataOption:=xlSortNormal
With ActiveWorkbook.Worksheets("Statistiche").Sort
.SetRange ActiveCell.Range("A1:BQ351")
.Header = xlGuess
.MatchCase = False
.Orientation = xlTopToBottom
.SortMethod = xlPinYin
.Apply
End With
Il problema è, come si può vedere, che la macro è piena di riferimenti sia al foglio che alla quantità di righe selezionate, ma non va bene perchè il loro numero può variare (il numero di righe selezionate indendo).

Come si può adattare quindi questa macro per far si che ordini le righe selezionate indipendentemente dalla loro quantità e dal foglio in cui si trovano?

Grazie mille
Rispondi quotando
  #2 (permalink)  
Vecchio 01-01-2008, 06:36 PM
Junior Member
 
Registrato dal: Jan 2008
Messaggi: 4
predefinito

Ciao.

Come primo suggerimento, per rendere relativo il foglio su cui lancerai la macro, sostituirei ActiveWorkbook.Worksheets("Statistiche") con Activesheet.

Seconda cosa, per rendere relativo anche la selezione delle celle, dichiarerei una variabile per la selezione delle celle (del tipo Selezione= Selection.Address) da mettere dopo che hai selezionato appunto tutte le celle che ti interessa elaborare (in questo caso dopo Range(Selection, Selection.End(xlDown)).Select). Questa variabile poi la inserirei al posto di tutte le dichiarazioni di Range fissi per ottenere così l'ordinamento in maniera relativa.

Tienici aggiornati
Ciao
Rispondi quotando
  #3 (permalink)  
Vecchio 01-06-2008, 08:21 PM
Administrator
 
Registrato dal: Jun 2007
Messaggi: 641
predefinito

Ho provato così:

codice:
Public Sub Ordina_Click()

Dim selezione

    Range("F2").Select
    ActiveCell.Rows("1:1").EntireRow.Select
    ActiveCell.Activate
    Range(Selection, Selection.End(xlDown)).Select
    
selezione = Selection.Address
    
    ActiveSheet.Sort.SortFields.Clear
    ActiveSheet.Sort.SortFields.Add Key:=selezione, SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:= _
        xlSortNormal
    ActiveSheet.Sort.SortFields.Add Key:=selezione, SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:= _
        xlSortNormal
    ActiveSheet.Sort.SortFields.Add Key:=selezione, SortOn:=xlSortOnValues, Order:=xlDescending, DataOption:= _
        xlSortNormal
    ActiveSheet.Sort.SortFields.Add Key:=selezione, SortOn:=xlSortOnValues, Order:=xlDescending, DataOption:= _
        xlSortNormal
    With ActiveSheet.Sort
        .SetRange selezione
        .Header = xlGuess
        .MatchCase = False
        .Orientation = xlTopToBottom
        .SortMethod = xlPinYin
        .Apply
    End With
  
End Sub
Il problema è che mi da questo errore:

Quote:
errore di run-time '1004':
errore definito dall'applicazione o dall'oggetto
Hai idea come risolvere?
Grazie ancora
Ciao




Rispondi quotando
Rispondi


Regole d'invio
Non puoi inserire discussioni
Non puoi inserire repliche
Non puoi inserire allegati
Non puoi modificare i tuoi messaggi

BB code è attivo
Le smilie sono attive
Il codice IMG è attivo
il codice HTML è disattivato
Trackbacks are attivo
Pingbacks are attivo
Refbacks are attivo


Discussioni simili
Discussione Ha iniziato questa discussione Forum Risposte Ultimo messaggio
Accedere a celle foglio Excel con javascript phpweb Informatica 0 11-12-2009 10:31 AM
Excel - metodo sort in excel pre 2007 Marcello_DF Informatica 0 04-01-2009 10:09 AM
Verificare la presenza di caratteri semplici in celle Excel Orlando Informatica 1 12-21-2008 06:05 PM
Ordinare dati Excel per un numero di colonne maggiore a tre Scuola Informatica 5 08-20-2008 06:27 PM
Riempendo con i colori le celle Excel, non compare il colore djfulmine Informatica 4 01-11-2008 08:44 PM


Tutti gli orari sono GMT +2. Attualmente sono le 09:44 AM.


© Copyright 2008-2022 powered by sitiweb.re - P.IVA 02309010359 - Privacy policy - Cookie policy e impostazioni cookie