Dear All, 
 setelah di coba macronya sudah jalan tapi masih mencari solusi agar tidak usah mengedit macro untuk merubah nama file "rev.xls" dan nama sheet di "rev.xls"
 karena data yang diterima dari customer selalu berubah baik nama file dan nama sheets juga range area
 apakah bisa dirubah nama file dan sheet menjadi variable 
 berikut cuplikannya 
 Function carinilai(ByVal daerah As Range, ByVal strcari As String) As Range
 Dim ketemu As Range
 Set ketemu = daerah.Find(
what:=strcari, LookIn:=xlValues, SearchOrder:=xlByRows)
 Set carinilai = ketemu
 End Function
 
 Sub ya()
 Dim filerev As String
 Dim sel, ketemu As Range
 
 kolomrev = 11
 kolomubah = 33
 
 rgrev = "g5:g130"
 rgubah = "a5:ag1800"
 
 Dim wk, wkrev As Workbook
 filerev = ActiveWorkbook.Path & "\Rev.xls"
 
 Set wk = ActiveWorkbook
 Set wkrev = Workbooks.Open(Filename:=filerev)
 
 For Each sel In wkrev.Sheets("Revised").Range(rgrev)
 nilaicari = sel.Offset(0, 0)
 nilaiganti = sel.Offset(0, kolomrev)
 
 Set ketemu = carinilai(wk.Sheets("list").Range(rgubah), nilaicari)
 If Not ketemu Is Nothing Then
 ketemu.Offset(0, kolomubah) = nilaiganti
  With ketemu.Offset(0, kolomubah).Interior
         .ColorIndex = 6
     End With
 
 End If
 Next
 End Sub
 
 regards,
 Gultom
 
 --- On Mon, 7/4/11, R T Gultom <ro_tag@yahoo.com> wrote:
 
 From: R T Gultom <ro_tag@yahoo.com>
 Subject: Re: [belajar-excel] Re: merevisi isi data
 To: belajar-excel@yahoogroups.com
 Date: Monday, July 4, 2011, 4:29 PM
 
  
 
 kalau berkenan  tolong dikoreksi karena waktu saya exekusi fail
 data terlampir
 
 --- On Mon, 7/4/11, sudarsono <jkssbma@live.com> wrote:
 
 From: sudarsono <jkssbma@live.com>
 Subject: [belajar-excel] Re: merevisi isi data
 To: belajar-excel@yahoogroups.com
 Date: Monday, July 4, 2011, 4:16 PM
 
  
 
 Function carinilai(ByVal daerah As Range, ByVal strcari As String) As Range
 
 Dim ketemu As Range
 
 Set ketemu = daerah.Find(what:=strcari, LookIn:=xlValues, SearchOrder:=xlByRows)
 
 Set cariterakhir = ketemu
 
 End Function
 
 koreksi menjadi
 
 Function carinilai(ByVal daerah As Range, ByVal strcari As String) As Range
 
 Dim ketemu As Range
 
 Set ketemu = daerah.Find(what:=strcari, LookIn:=xlValues, SearchOrder:=xlByRows)
 
 Set carinilai= ketemu
 
 End Function
 
 menurut saya apa yang disarankan Master Kid itu benar, gunakan fungsi cariniai untuk memperoleh baris yang diinginkan.....
 
 --- In belajar-excel@yahoogroups.com, R T Gultom <ro_tag@...> wrote:
 
 >
 
 > betul juga sih, tapi masih belum ketemu formatnya mengingat 
 
 > Ada data type barang dengan kondisi order no (IP), tanggal order, tanggal permintaan (bulan), jumlah per bulan (di insert baris) menkondisikan pengiriman barang karena tanggal permintaan bisa 5 kali dalam satu minggu sementara tangal pengiriman cuma satu kali dalam seminggu
 
 > dengan kondisi tertentu si customer bisa merubah tanggal permintaan sesuai dengan lain productnya mereka dan ini yang akan saya robah (dal;am case ini) untuk menyesuaikan kembali tanggal pengiriman
 
 > 
 
 >  setelah itu saya pivot untuk mengetaui per type per minggu dan per bulan berapa
 
 > 
 
 > 
 
 > --- On Mon, 7/4/11, Mr. Kid <mr.nmkid@...> wrote:
 
 > 
 
 > From: Mr. Kid <mr.nmkid@...>
 
 > Subject: Re: [belajar-excel] merevisi isi data
 
 > To: belajar-excel@yahoogroups.com
 
 > Date: Monday, July 4, 2011, 3:13 PM
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 >  
 
 > 
 
 > 
 
 > 
 
 >   
 
 > 
 
 > 
 
 >     
 
 >       
 
 >       
 
 >       Kenapa tidak buat master data yang berisi :
 
 > tgl_input , tgl_ip , nilai_ip
 
 > Kan gak repot mewarnai, gak repot cari-cari, bisa report banyak hal, sampai sejarah penggantiannya pun bisa.
 
 > 
 
 > ;-)
 
 > Kid.
 
 > 
 
 > 
 
 > 
 
 > 2011/7/4 R T Gultom <ro_tag@...>
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 >  
 
 > 
 
 > 
 
 > 
 
 >   
 
 > 
 
 > 
 
 >     
 
 >       
 
 >       
 
 >       mulai mendekati. tapi saya pelajari dulu untuk merubah variablenya
 
 > tapi kalau tidak salah sepintas bahwa di revisi kita sorot satu persatu sehingga macro exekusi dengan mengganti tangal di list cmiiw
 
 > 
 
 > 
 
 > ntar kalau mentok nanya lagi yah.....
 
 > sebenarnya masih ada tambahan yaitu setelah diganti tanggal dengan tanggal revisi di beri warna di range untuk menandakan itu adalah revisi, 
 
 > 
 
 > 
 
 > 
 
 > --- On Mon, 7/4/11, Sudarsono Suhenk <jkssbma@...> wrote:
 
 > 
 
 > 
 
 > 
 
 > From: Sudarsono Suhenk <jkssbma@...>
 
 > Subject: RE: [belajar-excel] merevisi isi data
 
 > 
 
 > 
 
 > To: "belajar excel yahoo.com" <belajar-excel@yahoogroups.com>
 
 > Date: Monday, July 4, 2011, 2:53 PM
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 >  
 
 > 
 
 > 
 
 > 
 
 >     
 
 >       
 
 >       
 
 >       
 
 > 
 
 > 
 
 > gunakan saja find :
 
 >  
 
 > Function carinilai(ByVal daerah As Range, ByVal strcari As String) As Range
 
 >     Dim ketemu As Range
 
 >     Set ketemu = daerah.Find(what:=strcari, LookIn:=xlValues, SearchOrder:=xlByRows)
 
 > 
 
 > 
 
 >     Set cariterakhir = ketemu
 
 > End Function
 
 >  
 
 > Sub ya()
 
 >     Dim sel As Range
 
 >     Dim wk As Workbook
 
 >     Set wk = ActiveWorkbook
 
 >     For Each sel In Workbooks("rev.xls").Sheets("ubah").Range("Q31:Q34")
 
 > 
 
 > 
 
 >         nilaicari = sel.Offset(0, 0)
 
 >         nilaiganti = sel.Offset(0, -1)
 
 >         Set ketemu = carinilai(wk.Sheets("Sumeri").Range("N8:O29"), nilaicari)
 
 >         If Not ketemu Is Nothing
 
 >  Then
 
 >             ketemu.Offset(0, -1) = nilaiganti
 
 >         End If
 
 >     Next
 
 >     
 
 >     
 
 > End Sub
 
 > 
 
 > '===============
 
 > To: belajar-excel@yahoogroups.com
 
 > 
 
 > 
 
 > From: ro_tag@...
 
 > Date: Mon, 4 Jul 2011 15:05:43 +0800
 
 > Subject: RE: [belajar-excel] merevisi isi data
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 >  
 
 > 
 
 > 
 
 > 
 
 > 
 
 >   
 
 > 
 
 > 
 
 >     
 
 >       
 
 >       
 
 >       sebenarnya yang dibutuhkan adalah sebagai berikut :
 
 > cari ip revisi di ip list dan 
 
 > ganti tanggal list dengan tanggal revisi
 
 > 
 
 > 
 
 > tapi membuat loopnya ribet saya utak-utik tidak ketemu
 
 > 
 
 > 
 
 > --- On Mon, 7/4/11, R T Gultom <ro_tag@...> wrote:
 
 > 
 
 > From: R T Gultom <ro_tag@...>
 
 > 
 
 > 
 
 > Subject: RE: [belajar-excel] merevisi isi data
 
 > To: belajar-excel@yahoogroups.com
 
 > Date: Monday, July 4, 2011, 2:01 PM
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 >  
 
 > 
 
 > 
 
 > 
 
 >     
 
 >       
 
 >       
 
 >       Wah mantab, tapi sayang persayaratannya adalah :
 
 > tidak ada penghapusan baris, karena isi dari baris revisi dengan list tidak sama, sehingga masih ada yang dipakai di list data baris sebelumnya
 
 > 
 
 > 
 
 > sebenarnya yang dibuthkan adalah bagaimana mengganti tangal yang di revisi saja tanpa menambah baris atau menghapus baris
 
 > karena masing2 data isinya selain dari IP dan tanggal adalah berbeda-beda
 
 > Regards,
 
 > Gultom
 
 > 
 
 > 
 
 > 
 
 > 
 
 > --- On Fri, 7/1/11, Sudarsono Suhenk <jkssbma@...> wrote:
 
 > 
 
 > From: Sudarsono Suhenk <jkssbma@...>
 
 > 
 
 > 
 
 > Subject: RE: [belajar-excel] merevisi isi data
 
 > To: "belajar excel yahoo.com" <belajar-excel@yahoogroups.com>
 
 > 
 
 > 
 
 > Date: Friday, July 1, 2011, 7:40 PM
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 >  
 
 > 
 
 > 
 
 > 
 
 >     
 
 >       
 
 >       
 
 >       
 
 > 
 
 > 
 
 > 
 
 > atau jika apapun yang ada di sheet ubah yang merupakan kondisi terakhir ( update ) gunakan cara ini :
 
 >  
 
 > Option Explicit
 
 > Sub GabungTabelAntarWorkbook()
 
 >     Dim AnakDulu As Boolean
 
 >     AnakDulu = True
 
 >     Dim INDUK As Range, ANAKK As Range
 
 > 
 
 > 
 
 >     Dim workbookutama, workbookanak As String
 
 >     workbookutama = ActiveWorkbook.Name
 
 >     Workbooks.Open Filename:=ActiveWorkbook.Path & "\rev.xls", Notify:=False
 
 >     workbookanak = ActiveWorkbook.Name
 
 > 
 
 > 
 
 >     Dim jumbaris As Long
 
 >     If AnakDulu Then
 
 >         Workbooks(workbookanak).Activate
 
 >         Set ANAKK = ctvUsedRange(Workbooks("rev.xls").Sheets("ubah"))
 
 >         Set INDUK = ctvUsedRange(ThisWorkbook.Sheets("Sumeri")).Offset(1,
 
 >  0)
 
 >         jumbaris = ANAKK.Rows.Count
 
 >     Else
 
 >         Workbooks(workbookutama).Activate
 
 >         Set INDUK = ctvUsedRange(ThisWorkbook.Sheets("Sumeri"))
 
 >         Set ANAKK = ctvUsedRange(Workbooks("rev.xls").Sheets("ubah")).Offset(1, 0)
 
 > 
 
 > 
 
 >         jumbaris = INDUK.Rows.Count
 
 >     End If
 
 >     Workbooks(workbookutama).Activate
 
 >     If AnakDulu Then
 
 >         ANAKK.Copy Destination:=Sheets("sheet1").Range("A1")
 
 >         INDUK.Copy Destination:=Sheets("sheet1").Range("A" & jumbaris + 1)
 
 > 
 
 > 
 
 >     Else
 
 >         INDUK.Copy
 
 >  Destination:=Sheets("sheet1").Range("A1")
 
 >         ANAKK.Copy Destination:=Sheets("sheet1").Range("A" & jumbaris + 1)
 
 >     End If
 
 >     Call hapusganda
 
 >     Call sortdata
 
 > 
 
 > 
 
 > End Sub
 
 > '===================================================================================================
 
 > Private Function ctvUsedRange(Optional Sht As Worksheet) As Range
 
 >    ' siti Vi // Bluewater, 24 Nov 2009
 
 > 
 
 > 
 
 >    ' last refine: Jurangmangu, 19 Jun 2011
 
 >    '---------------------------------------
 
 >     Dim FstRow As Long, FstCol As Integer
 
 >     Dim LstRow As Long, LstCol As Integer
 
 >     On Error Resume Next
 
 >     If Sht Is Nothing Then Set Sht = ActiveSheet ' Else Set Sht = Sht
 
 > 
 
 > 
 
 >     With Sht
 
 >        
 
 >  Sht.Select
 
 >         If Not Cells(1) = vbNullString Then
 
 >             FstRow = 1: FstCol = 1
 
 >         Else
 
 >             FstRow = .Cells.Find(What:="*", SearchDirection:=xlNext, SearchOrder:=xlByRows).Row
 
 > 
 
 > 
 
 >             FstCol = .Cells.Find(What:="*", SearchDirection:=xlNext, SearchOrder:=xlByColumns).Column
 
 >         End If
 
 >         LstRow = .Cells.Find(What:="*", SearchDirection:=xlPrevious, SearchOrder:=xlByRows).Row
 
 > 
 
 > 
 
 >         LstCol = .Cells.Find(What:="*", SearchDirection:=xlPrevious, SearchOrder:=xlByColumns).Column
 
 >         Set ctvUsedRange = Range(.Cells(FstRow,
 
 >  FstCol), .Cells(LstRow, LstCol))
 
 >     End With
 
 > End Function
 
 > Sub sortdata()
 
 >     Sheets("Sheet1").Select
 
 >     Range("A1").Select
 
 >     ActiveWorkbook.Worksheets("Sheet1").Sort.SortFields.Clear
 
 > 
 
 > 
 
 >     ActiveWorkbook.Worksheets("Sheet1").Sort.SortFields.Add Key:=Range("B2:B27") _
 
 >         , SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:=xlSortNormal
 
 >     ActiveWorkbook.Worksheets("Sheet1").Sort.SortFields.Add Key:=Range("A2:A27") _
 
 > 
 
 > 
 
 >         , SortOn:=xlSortOnValues, Order:=xlDescending, DataOption:=xlSortNormal
 
 >      With ActiveWorkbook.Worksheets("Sheet1").Sort
 
 >         .SetRange Range("A1:B27")
 
 >         .Header = xlYes
 
 > 
 
 > 
 
 >         .MatchCase
 
 >  = False
 
 >         .Orientation = xlTopToBottom
 
 >         .SortMethod = xlPinYin
 
 >         .Apply
 
 >     End With
 
 > End Sub
 
 > Sub hapusganda()
 
 >     Sheets("Sheet1").Select
 
 >     Range("A1").Select
 
 > 
 
 > 
 
 >     ActiveWorkbook.Worksheets("Sheet1").Sort.SortFields.Clear
 
 >     ActiveSheet.Range("$A$1:$B$27").RemoveDuplicates Columns:=Array(1, 2), Header _
 
 >         :=xlYes
 
 >     ActiveSheet.Range("$A$1:$B$27").RemoveDuplicates Columns:=2, Header:=xlYes
 
 > 
 
 > 
 
 > End Sub
 
 > 
 
 > Apa sudah sesuai ??? 
 
 > To: belajar-excel@yahoogroups.com
 
 > From: jkssbma@...
 
 > 
 
 > 
 
 > Date: Fri, 1 Jul 2011 17:09:37 +0700
 
 > Subject: RE: [belajar-excel] merevisi isi data
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 > 
 
 >  
 
 > 
 
 > 
 
 > 
 
 >   
 
 > 
 
 > 
 
 >     
 
 >       
 
 >       
 
 >       
 
 > 
 
 > 
 
 > 
 
 > 
 
 >  
 
 >  
 
 >   Bulan
 
 >   IP
 
 >  
 
 >  
 
 >   1-Jun-2011
 
 >   IP-3457
 
 >  
 
 >  
 
 >   2-Jun-2011
 
 >   IP-3458
 
 >  
 
 >  
 
 >   3-Jun-2011
 
 >   IP-3459
 
 >  
 
 >  
 
 >   4-Jun-2011
 
 >   IP-3460
 
 >  
 
 >  
 
 >   5-Jun-2011
 
 >   IP-3461
 
 >  
 
 >  
 
 >   6-Jun-2011
 
 >   IP-3462
 
 >  
 
 >  
 
 >   7-Jun-2011
 
 >   IP-3463
 
 >  
 
 >  
 
 >   8-Jun-2011
 
 >   IP-3464
 
 >  
 
 >  
 
 >   9-Jun-2011
 
 >   IP-3465
 
 >  
 
 >  
 
 >   10-Jun-2011
 
 >   IP-3466
 
 >  
 
 >  
 
 >   11-Jun-2011
 
 > 
 
 > 
 
 >   
 
 > IP-3467
 
 >  
 
 >  
 
 >   12-Jun-2011
 
 >   IP-3468
 
 >  
 
 >  
 
 >   13-Jun-2011
 
 >   IP-3469
 
 >  
 
 >  
 
 >   14-Jun-2011
 
 >   IP-3470
 
 >  
 
 >  
 
 >   15-Jun-2011
 
 >   IP-3471
 
 >  
 
 >  
 
 >   16-Jun-2011
 
 >   IP-3472
 
 >  
 
 >  
 
 >   17-Jun-2011
 
 >   IP-3473
 
 >  
 
 >  
 
 >   18-Jun-2011
 
 >   IP-3474
 
 >  
 
 >  
 
 >   19-Jun-2011
 
 >   IP-3475
 
 >  
 
 >  
 
 >   20-Jun-2011
 
 >   IP-3476
 
 >  
 
 >  
 
 >   21-Jun-2011
 
 >   IP-3477
 
 >  
 
 >  
 
 >   22-Jun-2011
 
 >   IP-3478
 
 >  
 
 > 
 
 > 
 
 >  
 
 > 
 
 > 
 
 >  
 
 >  
 
 >  
 
 >   Bulan
 
 >   IP
 
 >  
 
 >  
 
 >   13-Jun-2011
 
 >   IP-3465
 
 >  
 
 >  
 
 >   16-Jun-2011
 
 >   IP-3466
 
 >  
 
 >  
 
 >   4-Jun-2011
 
 > 
 
 > 
 
 >   
 
 > IP-3467
 
 >  
 
 >  
 
 >   21-Jun-2011
 
 >   IP-3468
 
 >  
 
 > 
 
 >  
 
 > 
 
 >  
 
 >  
 
 >  
 
 >   Bulan
 
 >   IP
 
 >  
 
 >  
 
 >   1-Jun-2011
 
 >   IP-3457
 
 >  
 
 >  
 
 > 
 
 >   2-Jun-2011
 
 >   IP-3458
 
 >  
 
 >  
 
 >   3-Jun-2011
 
 >   IP-3459
 
 >  
 
 >  
 
 >   4-Jun-2011
 
 >   IP-3460
 
 >  
 
 >  
 
 >   5-Jun-2011
 
 >   IP-3461
 
 >  
 
 >  
 
 >   6-Jun-2011
 
 >   IP-3462
 
 >  
 
 >  
 
 >   7-Jun-2011
 
 >   IP-3463
 
 >  
 
 >  
 
 >   8-Jun-2011
 
 >   IP-3464
 
 >  
 
 >  
 
 >   13-Jun-2011
 
 >   IP-3465
 
 >  
 
 >  
 
 >   16-Jun-2011
 
 >   IP-3466
 
 >  
 
 >  
 
 >   11-Jun-2011
 
 > 
 
 > 
 
 >   
 
 > IP-3467
 
 >  
 
 >  
 
 >   21-Jun-2011
 
 >   IP-3468
 
 >  
 
 >  
 
 >   13-Jun-2011
 
 >   IP-3469
 
 >  
 
 >  
 
 >   14-Jun-2011
 
 >   IP-3470
 
 >  
 
 >  
 
 >   15-Jun-2011
 
 >   IP-3471
 
 >  
 
 >  
 
 >   16-Jun-2011
 
 >   IP-3472
 
 >  
 
 >  
 
 >   17-Jun-2011
 
 >   IP-3473
 
 >  
 
 >  
 
 >   18-Jun-2011
 
 >   IP-3474
 
 >  
 
 >  
 
 >   19-Jun-2011
 
 >   IP-3475
 
 >  
 
 >  
 
 >   20-Jun-2011
 
 >   IP-3476
 
 >  
 
 >  
 
 >   21-Jun-2011
 
 >   IP-3477
 
 >  
 
 >  
 
 >   22-Jun-2011
 
 >   IP-3478
 
 >  
 
 > 
 
 >  
 
 >  
 
 > untuk IP-3467 apa tanggal terakhir 11 Juni 2011 , bukan 4 Juni 2011 ?
 
 >  
 
 > Sub GabungTabelAntarWorkbook()
 
 >    ' siti Vi // Bluewater, 1 Juli 2011
 
 >    ' workbook "rev.xls" harus sudah terbuka
 
 > 
 
 > 
 
 >    '---------------------------------------
 
 >    Dim INDUK As Range, ANAKK As Range
 
 >    Set INDUK = ctvUsedRange(ThisWorkbook.Sheets("Sumeri"))
 
 >    Set ANAKK = ctvUsedRange(Workbooks("rev.xls").Sheets("ubah")).Offset(1, 0)
 
 > 
 
 > 
 
 >  
 
 >     Dim jumbaris As Long
 
 >     jumbaris = INDUK.Rows.Count
 
 > 
 
 >     INDUK.Copy Destination:=Sheets("sheet1").Range("A1")
 
 >     ANAKK.Copy Destination:=Sheets("sheet1").Range("A" & jumbaris + 1)
 
 > 
 
 > 
 
 >     Call sortdata
 
 >    
 
 > End
 
 >  Sub
 
 >  
 
 > '===================================================================================================
 
 > Private Function ctvUsedRange(Optional Sht As Worksheet) As Range
 
 >    ' siti Vi // Bluewater, 24 Nov 2009
 
 > 
 
 > 
 
 >    ' last refine: Jurangmangu, 19 Jun 2011
 
 >    '---------------------------------------
 
 >    Dim FstRow As Long, FstCol As Integer
 
 >    Dim LstRow As Long, LstCol As Integer
 
 >    On Error Resume Next
 
 >    If Sht Is Nothing Then Set Sht = ActiveSheet ' Else Set Sht = Sht
 
 > 
 
 > 
 
 >    With Sht
 
 >         Sht.Select
 
 >       If Not Cells(1) = vbNullString Then
 
 >          FstRow = 1: FstCol = 1
 
 >      
 
 >  Else
 
 >          FstRow = .Cells.Find(What:="*", SearchDirection:=xlNext, SearchOrder:=xlByRows).Row
 
 >          FstCol = .Cells.Find(What:="*", SearchDirection:=xlNext, SearchOrder:=xlByColumns).Column
 
 > 
 
 > 
 
 >       End If
 
 >       LstRow = .Cells.Find(What:="*", SearchDirection:=xlPrevious, SearchOrder:=xlByRows).Row
 
 >       LstCol = .Cells.Find(What:="*", SearchDirection:=xlPrevious, SearchOrder:=xlByColumns).Column
 
 > 
 
 > 
 
 >       
 
 >       Set ctvUsedRange = Range(.Cells(FstRow, FstCol), .Cells(LstRow, LstCol))
 
 >    End With
 
 > End Function
 
 > '====================================================================================================
 
 > 
 
 > 
 
 > 
 
 > Sub sortdata()
 
 >     Sheets("Sheet1").Select
 
 >    
 
 >  Range("A1").Select
 
 >     ActiveWorkbook.Worksheets("Sheet1").Sort.SortFields.Clear
 
 >     ActiveWorkbook.Worksheets("Sheet1").Sort.SortFields.Add Key:=Range("B2:B27") _
 
 >         , SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:=xlSortNormal
 
 > 
 
 > 
 
 >     ActiveWorkbook.Worksheets("Sheet1").Sort.SortFields.Add Key:=Range("A2:A27") _
 
 >         , SortOn:=xlSortOnValues, Order:=xlDescending, DataOption:=xlSortNormal
 
 >      With ActiveWorkbook.Worksheets("Sheet1").Sort
 
 > 
 
 > 
 
 >         .SetRange Range("A1:B27")
 
 >         .Header = xlYes
 
 >         .MatchCase = False
 
 >         .Orientation = xlTopToBottom
 
 >         .SortMethod =
 
 >  xlPinYin
 
 >         .Apply
 
 >     End With
 
 >     ActiveSheet.Range("$A$