Results 1 to 7 of 7

Thread: Appendix Thread. Diet Protokol Coding Adaptions

  1. #1
    Fuhrer, Vierte Reich DocAElstein's Avatar
    Join Date
    Aug 2014
    Posts
    9,455
    Rep Power
    10

    Appendix Thread. Diet Protokol Coding Adaptions

    Test and Appendix postings for adaption of my Diet Protokol Codings for sharing and support of other excelfox Threads
    Last edited by DocAElstein; 03-10-2019 at 02:50 PM.

  2. #2
    Fuhrer, Vierte Reich DocAElstein's Avatar
    Join Date
    Aug 2014
    Posts
    9,455
    Rep Power
    10

    Columns 1 ans Columns 2 for sort

    _____ Workbook: ProAktuellex8600x2.xlsm ( Using Excel 2007 32 bit )
    Row\Col
    A
    B
    16672
    16673
    16674
    16675
    16676
    16677
    16678
    16679
    16680
    16681
    16682
    16683
    16684
    16685
    16686
    16687
    16688
    16689
    16690
    16691
    NesClas2Suc.75g 2malZuSuß 5.4g
    16692
    NesCals2.54NesMild20gSuc.6 2malZuSuß 11g
    16693
    NesClas1.21nesMild1.53Suc.6g 6.5g
    16694
    NesClas2.96Suc.4g 2malZuSuß 7.4g
    16695
    NesMild3.01Suc.8g Made 10_03_2019 2malZuSuß 10.8g
    16696
    3.06NesClassic .9gSuc Bisy zu suß Made 17_10_2018 2.8g
    16697
    3.07NesClassic .4gSuc OK suß Made 17_10_2018 4g
    16698
    1.95NesMild NesClassic1 Suc.6g Made 17_10_2018 5.8g
    16699
    2.2NesClassic .6gSuc Made 25_06_2018 Bisy suß 4.5g
    16700
    2G&G .5gSuc Made 25_06_2018 Bisy zu suß 5g
    16701
    2.21Nes.5gSuc ZuSuß Made 05_06_2018 6.7g
    16702
    2.18Nes.5gSuc OKSuß Made 05_06_2018 5.8g
    16703
    5.54Nes.35Suc OK Made 05_06_2018 11.8g
    16704
    2.02Nes2.5gSuc Made 15_04_2018 7,9g
    16705
    1.81Nes.3gSuc Made 15_04_2018 7,3g
    16706
    1.6NesMild1.1gSuc Made 15_04_2018 7,7g
    16707
    1.9NesMild1.6gSuc Made 15_04_2018 9,1g
    16708
    KakClasic210gSuc4.5g_02.01.2018 6.54g
    16709
    Nes58gSuc2.5gCacPur060gCebeCac256g_21_02_2018 18g
    16710
    Kaffe176gSuc2.5g Made 21_02_2018 7.7g
    16711
    Kaffee64g cacPuro138g Suc1g SkinnySchok175g Made 21_02_2018 14,5g
    16712
    Kaffee144g Cac Puro119g Suc2g Made 21_02_2018 9,8g
    16713
    Kaffee184g SkinnyShoko96g Suc 2g Made 21_02_2018 11,3g
    16714
    16715
    16716
    16717
    16718
    16719
    16720
    16721
    Worksheet: Sheet1

    Typically I have sections of 50 rows which “belong together”, ( 49grouped + 1 below ) , and things may be added. It is easier to add anywhere in the section and then do a sort on the entire group, or part thereof , as required..
    49grouped+1.JPG : https://imgur.com/a8rflEn
    49grouped+1.JPG
    The group above is 16721 ; 16722 ; 16723 .... 16672 = (16672-16721)+1 = 50 rows
    Last edited by DocAElstein; 03-10-2019 at 08:35 PM.

  3. #3
    Fuhrer, Vierte Reich DocAElstein's Avatar
    Join Date
    Aug 2014
    Posts
    9,455
    Rep Power
    10

    117 columns of etwa 3488 columns

    _____ Workbook: ProAktuellex8600x2.xlsm ( Using Excel 2007 32 bit )
    Row\Col
    A
    B
    C
    D
    E
    F
    G
    H
    I
    J
    K
    L
    M
    N
    O
    P
    Q
    R
    S
    T
    U
    V
    W
    X
    Y
    Z
    AA
    AB
    AC
    AD
    AE
    AF
    AG
    AH
    AI
    AJ
    AK
    AL
    AM
    AN
    AO
    AP
    AQ
    AR
    AS
    AT
    AU
    AV
    AW
    AX
    AY
    AZ
    BA
    BB
    BC
    BD
    BE
    BF
    BG
    BH
    BI
    BJ
    BK
    BL
    BM
    BN
    BO
    BP
    BQ
    BR
    BS
    BT
    BU
    BV
    BW
    BX
    BY
    BZ
    CA
    CB
    CC
    CD
    CE
    CF
    CG
    CH
    CI
    CJ
    CK
    CL
    CM
    CN
    CO
    CP
    CQ
    CR
    CS
    CT
    CU
    CV
    CW
    CX
    CY
    CZ
    DA
    DB
    DC
    DD
    DE
    DF
    DG
    DH
    DI
    DJ
    DK
    DL
    DM
    1
    Food Produkt
    Morgen
    Mittag
    Abend
    Gruppieren Food Group Hit Me! x
    Kcal
    Fett
    Eiweiß
    Koh
    Zucker
    Ballastoffe
    Wasser
    kalium
    Natrium+
    Kalzium
    Magnesium
    chlorid
    Phosphor
    Schwefel
    OrganischeSäuren
    Alkohol
    Ca2+
    Mg2+
    PO43-
    SO42-
    HCO3-
    MF
    Retinoläquivalent
    A (Retinol)
    ß-Carotin
    D (Calciferol)
    E (Tocopherol)
    a-Tocopherol
    68
    69
    K (Phyllochinon)
    71
    72
    73
    B1 (Thiamin)
    75
    B2 (Riboflavin)
    77
    B3 Niacin
    79
    Niacinäquivalent
    81
    B5 Panthothensäure
    83
    B6 (Pyridoxin)
    85
    B7 Biotin (H)
    87
    B9 Folsäure
    Folic acid FOLAC (g)
    Folate, food FOLFD (g)
    Folate, DFE FOLDFE (g)
    free folic acid
    para Aminobenzosäure
    94
    95
    B12 (Cobalamin)
    Ino war heit
    C (Ascorbinsäure)
    99
    (Mineralstoffen)Spurenelement Eisen Zink Kupfer Mangan Selenium, Se SE (µg) Fluorid jod Silizium
    2
    0
    GCAL
    ZF
    ZE
    ZK
    KMD
    ZB
    ZW
    MNA
    sonst. organischen Säuren
    ZA
    Fluorid
    Vitamin B3 (Niacin)
    Folate, total FOL
    Mineral MFE MZN MCU MMN MF MJ
    Worksheet: Sheet1
    Last edited by DocAElstein; 03-10-2019 at 02:59 PM.

  4. #4
    Fuhrer, Vierte Reich DocAElstein's Avatar
    Join Date
    Aug 2014
    Posts
    9,455
    Rep Power
    10

    Existing routine using VBA Range:Sort Method in single line

    Existing code
    Main sort routine
    Code:
    Sub ReorgBy3Criteria()
    Rem 0 error handling
    On Error GoTo TheEnd:
    Rem 1 worksheet info
     Call DieseArbeitsmappe1.FillMeGlobsUpMate ' Global variables filled for example that for open daily Diet Protokol
    Dim objwinToSort As Object: Set objwinToSort = Windows("" & DieseArbeitsmappe1.ProWb.Name & "") 'Mainly for convenience, but would give possibility of referring to a sheet "quasi" as the active even if you do not have got it "active" in front of you
    Dim wksToSort As Worksheet: Set wksToSort = DieseArbeitsmappe1.ProWb.Worksheets("" & "Sheet1" & "")
    Rem 2 Range for sort is based on Window selection. For convenience only rows selection is necerssary
    Dim StRow As Long, stClm As Long, StpRow As Long, StpClm As Long
    Let StRow = objwinToSort.Selection.Row: Let stClm = 1 'objwinToSort.Selection.Column ' Select any column or columns of rows to sort
    Let StpRow = StRow + objwinToSort.Selection.Rows.Count - 1: Let StpClm = 3488 ' 3482 '454 '99
    Dim rngToSort As Range: Set rngToSort = wksToSort.Range(CL(stClm) & StRow & ":" & CL(StpClm) & StpRow) ' Use column letter function for column letters
    Dim ArrrngOrig() As Variant: Let ArrrngOrig() = rngToSort.Value ' This is used as a back up to restore the original range
                          Let Application.EnableEvents = False                                         ' This is necerssary to turn off some event coding which I have which springs into action when anything is done in the worksheet
    Rem 3 VBA Range.Sort Method
    '       xlDescending Biggest at Top   H Kcal                         J Fett                                                   L eiweiss
    'rngToSort.Sort Key1:=wksToSort.Columns("h"), order1:=xlDescending, Key2:=wksToSort.Columns("j"), order2:=xlDescending, Key3:=wksToSort.Columns("l"), order3:=xlDescending 'X Nat
    'Standard unter    ----    Kcal Highest H  ,at Top               , second most J Fett          , highest at Top      , third Natrium X             ,    most at top
    rngToSort.Sort Key1:=wksToSort.Columns("H"), order1:=xlDescending, Key2:=wksToSort.Columns("J"), order2:=xlDescending, Key3:=wksToSort.Columns("X"), order3:=xlDescending 'X Nat
                          Let Application.EnableEvents = True
    Rem 4 Msg Box check if all is well, if not put original enties back in.                                                                                 COMMENTED OUT FOR SPEED TESTS
    Dim Response As Integer 'In VBA Butons "yes is 6, 7 is "no"
     Let Response = MsgBox(Prompt:="Is all OK?", Buttons:=vbYesNo, Title:="File Check") ' Displays a message box with the yes and no options.
        If Response = vbYes Then 'Do nothing, that is to say just carry on after End of If
         ' all is well - carry on after  End If
        Else
         Let Application.EnableEvents = False
         Let rngToSort.Value2 = ArrrngOrig() 'Full repair!!Put back as it was
         Let Application.EnableEvents = True
        End If
    Exit Sub ' Routine end if no errors____________________________________________________________________
    TheEnd: ' Error handling code section
     Let Application.EnableEvents = True                                                                      ' In the Case of an error I want to ensure that I turn back on my normal events. This is necerssary incase the error occured between after a  .EnableEvents = False   and before a  .EnableEvents = True
     MsgBox Prompt:=Err.Number & vbCr & vbLf & Err.Description
    End Sub 'ReorgBy3Criteria
    Coding Walkthrough Explanation
    Rem 1 is not particularly relevant to the Sort process. This is just getting at the data worksheet containing the spreadsheet range to be sorted.
    In this actual example a global variable, is held in the ThisWorkbook code module, ProWb, holding the data workbook as an object. This would usually be filled on opening of the File containing the sort routine. Just in case it may not be filled, a routine is called to fill it. ( For English Excel, the routine would be placed in the ThisWorkbook code module, and referencing this variable would be by ThisWorkbook. FillMeGlobsUpMate in place of the German equivalent in my pre pre alpha Excel 2019 version which has the objects module DieseArbeitsmappe1
    Rem 2 concerns determination of the range to be sorted, which in this case is the selection made in the active Window. In the actual example there are many columns and the number is known. The rows can be variable. ( Typical row selections are made in a large table and just those rows are sorted based on a few of the column values )
    The Selection is used to obtain the start ( Top ) row, from an available property
    objwinToSort.Selection.Row
    and the stop ( bottom ) row is , as is often the case in VBA things, not available as a property, but the rows count is , so the typical formula is used to get that of pseudo like Stop = Start + ( RowCount – 1 )
    StRow + objwinToSort.Selection.Rows.Count - 1
    The column numbers of the range are hardcoded
    I prefer to obtain my Range from the Range property method like Range(“A23:ZZ89”), so in order to do this when I use the column numbers, I use a simple function, CL( )
    An array is made , ArrrngOrig() , to use as a back up from which to restore the original unsorted range if required later

    Rem 3 main sort
    A typical example is used , showing the Range.Sort method to sort the range by 3 columns. As main sort this will be having Kcal values of the highest at the top. For similar Kcal values the sort will be by the Fat , again with the larges at the top. In case any rows have the same Kcal and Fat values, then a last sort for those rows is made by highest Natrium at the top. ( Natrium = Sodium , which is a Salt derivative )
    Code:
    'Standard unter    ----    Kcal Highest H  ,at Top               , second most J Fett          , highest at Top      , third Natrium X             ,    most at top
    rngToSort.Sort Key1:=wksToSort.Columns("H"), order1:=xlDescending, Key2:=wksToSort.Columns("J"), order2:=xlDescending, Key3:=wksToSort.Columns("X"), order3:=xlDescending
    Rem 4 Possible reset of original range order
    I would tend to usually include such a coding section as this in any sorting routine. The user has the possibility to accept the sorted range or use the array, ArrrngOrig(), to restore the original range unsorted.

    Required Function and routine
    In normal code module
    Code:
    Function CL(ByVal lclm As Long) As String 'Using chr function and Do while loop      For example http://www.excelforum.com/excel-programming-vba-macros/796472-how-to-go-from-column-number-to-column-letter.html
    'Dim rest As Long 'Variable for what is "left over" after subtracting as many full 26's as possible
        Do
        '    Let rest = ((lclm - 1) Mod 26) 'Gives 0 to 25 for Column Number "Left over" 1 to 26. Better than ( lclm Mod 26 ) which gives 1 to 25 for clm 1 to 25 then 0 for 26
        '    Let FukOutChrWithDoWhile = Chr(65 + rest) & FukOutChrWithDoWhile 'Convert rest to Chr Number, initially with full number so the "units" (0-25), then number of 26's left over (if the number was so big to give any amount of 26's in it, then number of 26's in the 26's left over (if the number was so big to give any amount of 26 x 26's in it, Enit ?
        '    'OR
        Let CL = Chr(65 + (((lclm - 1) Mod 26))) & CL
        Let lclm = (lclm - (1)) \ 26 'This gives the number of 26's ( if any ), but just the excact part, in the next number down , - so applying the rest formula to this new number will again leave a difference "left over" rest.
        'lclm = (lclm - (rest + 1)) \ 26 ' As the number is effectively truncated here, any number from 1 to (rest +1)  will do in the formula
        Loop While lclm > 0 'Only loop further if number was big enough to still have 0-25's in it
    End Function
    '   https://www.excelforum.com/development-testing-forum/1101544-thread-post-appendix-no-reply-needed-please-do-not-delete-thanks-4.html#post4213887
    Required routine in ThisWorkbook code module
    In this actual example a global variable, is held in the ThisWorkbook code module, ProWb, holding the data workbook as an object. This would usually be filled on opening of the File containing the sort routine. Just in case it may not be filled, a routine is called to fill it. ( For English Excel, the routine would be placed in the ThisWorkbook code module, and referencing this variable would be by ThisWorkbook. FillMeGlobsUpMate in place of the German equivalent in my pre pre alpha Excel 2019 version which has the objects module DieseArbeitsmappe1
    Code:
    '' DieseArbeitsmappe1
    ' In Lis Workbook code module
    Option Explicit
    Public ProWb As Workbook ' 
    Public Sub FillMeGlobsUpMate()
        For Each ProWb In Workbooks
            If VBA.Left$(ProWb.Name, 18) = "ProAktuellex8600x2" Then
             'Set ProWb = ProWb ' Don't need this - it is effectively left set at current Workbook in loop, because you exit for.
             Set LisWbProWb = ProWb
             Exit For ' This is important or else you will need to uncommment Set ProWb = ProWb
            Else
             ' MsgBox Prompt:="You don't seem to have a Pro open, my luv, x" The error handling,  PoGoStRory:  will do this for me onn the attempt at  ProWb.Name
            End If
        Next ProWb
    End Sub





    Data Workbook ( for sample range ):
    "ProAktuellex8600x2.xlsx" https://app.box.com/s/sspcm7a4w3t99wzezruxep7e7j51khju
    Last edited by DocAElstein; 03-10-2019 at 08:12 PM.

  5. #5
    Fuhrer, Vierte Reich DocAElstein's Avatar
    Join Date
    Aug 2014
    Posts
    9,455
    Rep Power
    10
    In support of this excelfox post:
    http://www.excelfox.com/forum/showth...ll=1#post11037

    Code:
    ' Calling code for the main Array sort routine
    Sub CallArraySort()
    Rem 0 error handling
    On Error GoTo TheEnd:
    Rem 1 worksheet info
    ' Call DieseArbeitsmappe1.FillMeGlobsUpMate ' Global variables filled for example that for open daily Diet Protokol
    Dim objwinToSort As Object: Set objwinToSort = Windows("" & ThisWorkbook.Name & "") 'Mainly for convenience, but would give possibility of referring to a sheet "quasi" as the active even if you do not have got it "active" in front of you
    Dim wksToSort As Worksheet ': Set wksToSort = DieseArbeitsmappe1.ProWb.Worksheets("" & "Sheet1" & "")
     Set wksToSort = ThisWorkbook.Worksheets("Sheet1")
    Rem 2 Range for sort is based on Window selection. For convenience only rows selection is necerssary
    Dim StRow As Long, stClm As Long, StpRow As Long, StpClm As Long
    Let StRow = objwinToSort.Selection.Row: Let stClm = 1 'objwinToSort.Selection.Column ' Select any column or columns of rows to sort
    Let StpRow = StRow + objwinToSort.Selection.Rows.Count - 1: Let StpClm = 3488 ' 3488 ' 3482 '454 '99
    Dim rngToSort As Range: Set rngToSort = wksToSort.Range(CL(stClm) & StRow & ":" & CL(StpClm) & StpRow) ' Use column letter function for column letters
    Dim ArrrngOrig() As Variant: Let ArrrngOrig() = rngToSort.Value ' This is used as a back up to restore the original range
                          Let Application.EnableEvents = False                                         ' This is necerssary to turn off some event coding which I have which springs into action when anything is done in the worksheet
    Rem 3 Array sort routine alternative coding
    '3a) argumants for Called routine
    Dim cnt As Long, strIndcs As String: Let strIndcs = " "
        For cnt = 1 To rngToSort.Rows.Count
         Let strIndcs = strIndcs & cnt & " "
        Next cnt
    Debug.Print strIndcs
    Dim arrTS() As Variant: Let arrTS() = ArrrngOrig()
    '3b) Do sort
     Call SimpleArraySort6(1, arrTS(), strIndcs, " 8 Desc 10 Desc 24 Desc ")
     Let rngToSort.Value = arrTS()
    Rem 4 Msg Box check if all is well, if not put original enties back in.                                                                                 COMMENTED OUT FOR SPEED TESTS
    Dim Response As Integer 'In VBA Butons "yes is 6, 7 is "no"
     Let Response = MsgBox(Prompt:="Is all OK?", Buttons:=vbYesNo, Title:="File Check") ' Displays a message box with the yes and no options.
        If Response = vbYes Then 'Do nothing, that is to say just carry on after End of If
         ' all is well - carry on after  End If
        Else
         Let Application.EnableEvents = False
         Let rngToSort.Value = ArrrngOrig() 'Full repair!!Put back as it was
         Let Application.EnableEvents = True
        End If
    Exit Sub ' Routine end if no errors____________________________________________________________________
    TheEnd: ' Error handling code section
     Let Application.EnableEvents = True                                                                      ' In the Case of an error I want to ensure that I turn back on my normal events. This is necerssary incase the error occured between after a  .EnableEvents = False   and before a  .EnableEvents = True
     MsgBox Prompt:=Err.Number & vbCr & vbLf & Err.Description
    End Sub
    '

    The main recursion routine Called by the above routine,
    Sub SimpleArraySort6(ByVal CpyNo As Long, ByRef arsRef() As Variant, ByVal strRws As String, ByVal strKeys As String)
    , is here
    http://www.excelfox.com/forum/showth...ll=1#post10994
    and in this File
    "ProAktuellex8600x2Sort1.xlsm" https://app.box.com/s/d6isabudadt3swnryxiz7motspzeqa17
    Last edited by DocAElstein; 03-14-2019 at 11:09 PM.

  6. #6
    Fuhrer, Vierte Reich DocAElstein's Avatar
    Join Date
    Aug 2014
    Posts
    9,455
    Rep Power
    10
    test post for URL
    A Folk, A Forum, A Fuhrer ….

  7. #7
    Fuhrer, Vierte Reich DocAElstein's Avatar
    Join Date
    Aug 2014
    Posts
    9,455
    Rep Power
    10
    test post for url
    A Folk, A Forum, A Fuhrer ….

Similar Threads

  1. Replies: 185
    Last Post: 05-22-2024, 10:02 PM
  2. VBA to Reply All To Latest Email Thread
    By pkearney10 in forum Outlook Help
    Replies: 11
    Last Post: 12-22-2020, 11:15 PM
  3. Replies: 19
    Last Post: 04-20-2019, 02:38 PM
  4. Replies: 2
    Last Post: 04-10-2015, 04:18 PM
  5. add an addition cell colour to coding
    By peter renton in forum Excel Help
    Replies: 2
    Last Post: 11-20-2014, 05:16 PM

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts
  •