I've got a challenge for anyone up for it. Below are the rules and some formatted example data. It's supposed to be tab-delimited but if email borks it, you can grab a zip file here:
<https://dl.dropboxusercontent.com/u/23431607/testColumnData.txt.zip>

DATA FORMAT:

Each tab-delimited line has four columns which describe a particular part of the whole, similar to an expanded array. The last column uses a pipe to delimit its own three items: type|op1|op2.

RULES:

1. Every ID, Section, Subsection and Type must be unique across the entire list.

2. While every Type must be unique, a Type can be the same as the Subsection it's in. This is the only non-unique exception.

3. OP1 and OP2 must each be one of "DIV, MULT, PLUS, MINUS, COUNT". For each line, OP1 and OP2 must be different.

4. The first two lines of each ID have only two or three column entries respectively. Otherwise, every line must contain all four column entries. If the line has a fourth column entry, it must contain three pipe-delimited items and the last two of these must be OP1 and OP2.

5. Lines must be in order; all IDs are grouped, and within those, all Sections are grouped. Within those, all Subsections are together.

TASK:

Find irregular or missing entries. You don't have to fix them, just report them.

There may be typos. Determine whether a line is out of order (the same ID/Section/Subsection exists elsewhere in a legitimate location) or contains a typo (there is no other instance.)

Bonus points if you can identify and report the reason the line is irregular; i.e., wrong order, typo, missing entry, etc.

================================
ID      SECTION SUBSECTION      TYPE|OP1|OP2
AB      MediumOrchid            
AB      MediumOrchid    OrangeRed2      
AB      MediumOrchid    Khaki2  DeepPink1|DIV|MULT
AB      MediumOrchid    Gray100 Gray100|MULT|DIV
AB      MediumOrchid    Gray100 Gray100|MULT|DIV
AB      MediumOrchid    Gray100 PeachPuff|MINUS|MULT
AB      Gray40  Gray39  AntiqueWhite4|MULT|MINUS
AB      Gray40  Gray39  Ivory3|MULT|MINUS
AB      Gray40  Gray39  PowderBlue|MINUS|DIV
AB      Gray40  Chocolate4      DarkKhaki|PLUS|MINUS
AB      Gray40  Chocolate4      RoyalBlue4|MINUS|PLUS
AB      Gray40  Chocolate4      LightCyan3|MINUS|PLUS
AB      DarkGoldenrod2  AntiqueWhite3   Gray67|MINUS|DIV
AB      DarkGoldenrod2  AntiqueWhite3   DarkOrchid2|MULT|DIV
AB      DarkGoldenrod2  DeepPink3       Gray81|PLUS|MINUS
AB      DarkGoldenrod2  DeepPink3       Ivory4|MULT|DIV
AB      DarkGoldenrod2  DeepPink3       Tomato4|MINUS|PLUS
AB      Gray16  SpringGreen     Gray71|DIV|MULT
AB      Gray16  Magenta2        MistyRose|PLUS|DIV
AB      Gray16  Magenta2        Magenta2|DIV|MINUS
AB      Gray16  Gray28  SlateGray4|MINUS|DIV
AB      Gray16  Gray28  HotPink2|COUNT|MULT
AB      Gray16  Gray28  NavajoWhite2|COUNT|PLUS
AB      Gray16  Gray28  CadetBlue3|MINUS|MULT
AB      Gray40  Chocolate4      Chocolate4|MINUS|MULT
AB      Gray16  DarkTurquoise   LightSteelBlue1|COUNT|MULT
AB      Gray16  DarkTurquoise   PaleTurquoise2|DIV|MINUS
AB      Gray16  DarkTurquoise   Gray98|MINUS|MULT
CD      OliveDrab1              
CD      OliveDrab1      Gray47  
CD      OliveDrab1      Gray47  Ivory2|PLUS|DIV
CD      OliveDrab1      Azure2  Gray23|MULT|PLUS
CD      OliveDrab1      Azure2  LightBlue4|MINUS|PLUS
CD      OliveDrab1      Azure2  DarkGoldenrod4|DIV|PLUS
CD      Firebrick4      Gray49  Snow1|MULT|MINUS
CE      Firebrick4      Gray49  Gold3|COUNT|MULT
CD      Firebrick4      Gray49  Plum1|DIV|MULT
CD      Firebrick4      LightCyan2      DarkOliveGreen3|MULT|PLUS
CD      Firebrick4      LightCyan2      Gray54|PLUS|MINUS
CD      Firebrick4      LightCyan2      Maroon4|PLUS|DIV
CD      Firebrick4      LavenderBlush4  LavenderBlush4|COUNT|PLUS
CD      Firebrick4      LavenderBlush4  Gray41|COUNT|PLUS
CD      Firebrick4      LavenderBlush4  LightYellow2|MINUS|MULT
CD      Firebrick4      CornSilk4       CornSilk4|PLUS|MINUS
CD      Firebrick4      CornSilk4       DarkSeaGreen3|PLUS|MULT
CD      MediumOrchid1   RoyalBlue2      Gray61|PLUS|MULT
CD      MediumOrchid1   RoyalBlue2      Gray63|MINUS|PLUS
CD      MediumOrchid1   Aquamarine2     HotPink1|COUNT|DIV
CD      MediumOrchid1   Aquamarine2     Plum3|COUNT|PLUS
CD      MediumOrchid1   Gray77  MediumOrchid3|MINUS|DIV
CD      MediumOrchid1   Gray77  Gray88|COUNT|DIV
CD      MediumOrchid1   Gray77  MediumSpringGreen|MINUS|MULT
CD      MediumOrchid1   Gray77  DarkOliveGreen1|PLUS|DIV
CD      Gray87  DarkSlateGray4  LightPink2|DIV|MULT
CD      Gray87  DarkSlateGray4  Sienna3|DIV|MINUS
CD      Gray87  DarkSlateGray4  Wheat3|MINUS
CD      Gray87  LightYellow1    Black|MULT|PLUS
CD      Gray87  LightYellow1    Gray85|COUNT|DIV
CD      Gray87  LightYellow1    AntiqueWhite2|DIV|PLUS
CD      Gray87  LightYellow1    OrangeRed1|MULT|DIV
CD      Gray87  Honeydew4       Honeydew3|MINUS|PLUS
CD      Gray87  Honeydew4       Gray32|MULT|PLUS
CD      Gray87  Honeydew4       Khaki1|DIV|MULT
CD      Gray87  Honeydew4       Azure4|COUNT|DIV
CD      LightGoldenrod2 Orange2 Orange2|COUNT|PLUS
CD      LightGoldenrod2 Orange2 Gray29|PLUS|PLUS
CD      LightGoldenrod2 Orange2 Yellow3|DIV|PLUS
CD      LightGoldenrod2 LightSalmon2    AntiqueWhite1|MINUS|PLUS
CD      LightGoldenrod2 LightSalmon2    Coral3|MINUS|MULT
CD      LightGoldenrod2 LightSalmon2    LightSeaGreen|MINUS|MULT
CD      LightGoldenrod2 LightSalmon2    Aquamarine3|MINUS|DIV
CD      LightGoldenrod2 LightSkyBlue4   Wheat4|MULT|PLUS
CD      LightGoldenrod2 LightSkyBlue4   Gray12|MINUS|MULT
CD      LightGoldenrod2 LightSkyBlue4   LightYellow3|DIV|PLUS
CD      LightGoldenrod2 Gray57  Gray57|DIV|MULT
CD      LightGoldenrod2 Gray57  LightBlue3|DIV|PLUS
CD      LightGoldenrod2 Gray57  Gray84|DIV|MINUS
CD      LightGoldenrod2 Gray57  Bisque2|DIV|MINUS
CD      LightGoldenrod2 Sienna1 CadetBlue1|COUNT|DIV
CD      LightGoldenrod2 Sienna1 Coral4|MINUS|PLUS
CD      LightGoldenrod2 Sienna1 Gold4|COUNT|DIV
EF      Chocolate1      LavenderBlush2  Gray52|COUNT|MINUS
EF      Chocolate1      LavenderBlush2  Gray74|PLUS|MULT
EF      Chocolate1      LightBlue1      PapayaWhip|MULT|DIV
EF      Chocolate1      Gray76  MediumGoldenrod|DIV|PLUS
EF      Gray25  SpringGreen2    OliveDrab3|COUNT|MULT
EF      Gray25  SpringGreen2    MediumPurple2|MINUS|PLUS
EF      Gray25  SpringGreen2    Khaki3|COUNT|MINUS
EF      Gray25  SpringGreen4    Gray17|MINUS|PLUS
EF      Gray25  SpringGreen4    Firebrick1|DIV|PLUS
EF      Gray25  LightGoldenrod1 LemonChiffon3|COUNT|PLUS
EF      Gray25  LightGoldenrod1 SkyBlue3|MINUS|PLUS
EF      Gray25  LightGoldenrod1 DarkSeaGreen2|COUNT|PLUS
EF      Gray25  LightGoldenrod1 Gray0|COUNT|DIV
EF      Gray25  Gray14  Gray83|MINUS|DIV
EF      Gray25  Gray14  Tan2|COUNT|DIV
EF      Gray25  Gray14  Gray60|PLUS|MULT
EF      LightPink4      PaleVioletRed4  MistyRose2|COUNT|PLUS
EF      LightPink4      PaleVioletRed4  DarkGoldenrod1|PLUS|DIV
EF      LightPink4      PaleVioletRed4  Gray56|DIV|MINUS
EF      LightPink4      PaleVioletRed4  SlateBlue4|MULT|MINUS
EF      LightPink4      DeepSkyBlue3    LightCyan4|MULT|DIV
EF      LightPink4      Gold2   Gold2|COUNT|DIV
EF      LightPink4      Gold2   DeepPink2|MULT|PLUS
EF      LightPink4      Gold2   LightSkyBlue3|DIV|MINUS
EF      LightPink4      Gold2   SandyBrown|DIV|MINUS
EF      LightPink4      RosyBrown2      Tan1|MINUS|PLUS
EF      LightPink4      RosyBrown2      Gray66|DIV|MINUS
EF      LightPink4      RosyBrown2      LavenderBlush3|PLUS|DIV
EF      LightPink4      RosyBrown2      SlateBlue1|DIV|PLUS
EF      LightPink4      Tomato2 PaleGreen2|PLUS|DIV
EF      LightPink4      Tomato2 Chocolate2|DIV|PLUS
EF      LightPink4      Tomato2 DarkSlateGray2|DIV|MINUS
EF      LightPink4      Tomato2 DarkOrange1|MINUS|PLUS
EF      SpringGreen1    Gray82  Gray11|PLUS|MULT
EF      SpringGreen1    Gray82  Azure3|MINUS|MINUS
EF      SpringGreen1    Gray82  PaleVioletRed1|COUNT|PLUS
EF      SpringGreen1    LightBlue2      Aquamarine1|MINUS|DIV
EF      SpringGreen1    LightBlue2      PaleGreen1|COUNT|PLUS
EF      SpringGreen1    LightBlue2      Gray72|MINUS|DIV
EF      SpringGreen1    LightBlue2      Gray51|MULT|DIV
EF      SpringGreen1    Seashell1       Gray21|MULT|MINUS
EF      SpringGreen1    Seashell1       Gray97|MULT|DIV
EF      SpringGreen1    Seashell1       Maroon1|MINUS|MULT
EF      DarkGray        DodgerBlue1     Gray31|MINUS|PLUS
EF      DarkGray        DodgerBlue1     Gray30|MINUS|PLUS
EF      DarkGray        DodgerBlue1     Firebrick3|MULT|PLUS
EF      DarkGray        DodgerBlue1     SeaGreen1|COUNT|MINUS
EF      DarkGray        Gray69  Gray69|PLUS|MINUS
EF      DarkGray        Gray69  Burlywood2|PLUS|DIV
EF      DarkGray        Gray69  IndianRed1|COUNT|DIV
EF      DarkGray        Gray69  Gray69|MULT|PLUS
EF      DarkGray        LightSkyBlue2   LightGoldenrod3|MINUS|MULT
EF      DarkGray        LightSkyBlue2   LightSteelBlue2|DIV|PLUS
EF      DarkGray        LightSkyBlue2   Gray33|COUNT|MULT
EF      DarkGray        LightSkyBlue2   SlateGray3|PLUS|MULT
GH      Purple4         
GH      Purple4 CornSilk3       
GH      Purple4 CornSilk3       DarkSeaGreen1|MINUS|DIV
GH      Purple4 Gray39  MediumPurple4|MINUS|PLUS
GH      Purple4 Gray39  LightGray|MINUS|PLUS
GH      Purple4 Gray39  Gray50|COUNT|DIV
GH      Purple4 Tan4    Tan4|DIV|MULT
GH      Purple4 Tan4    Bisque3|DIV|MINUS
GH      Purple4 Tan4    Peru|PLUS|MINUS
GH      Purple4 Tan4    PeachPuff4|PLUS|DIV
GH      Purple4 Gray15  MistyRose4|MULT|DIV
GH      Purple4 Gray15  PaleGoldenrod|DIV|PLUS
GH      Purple4 Gray46  Gray37|PLUS|DIV
GH      Gray70  RosyBrown3      Honeydew1|PLUS|DIV
GH      Gray70  RosyBrown3      PaleGreen3|DIV|PLUS
GH      Gray70  RosyBrown3      PaleTurquoise4|PLUS|MINUS
GH      Gray70  Burlywood3      LightPink1|MINUS|DIV
GH      Gray70  Burlywood3      Gray91|MULT|DIV
CD      Gray70  Burlywood3      Gray20|DIV|PLUS
GH      Gray26  Tomato3 Gray45|COUNT|MULT
GH      Gray26  Tomato3 Transparent|COUNT|MULT
GH      Gray26  Tomato3 LightCoral|MULT|MINUS
GH      Gray26  LightSlateGray  Gray95|MINUS|MULT
GH      Gray26  LightSlateGray  Snow2|MULT|MINUS
GH      Gray26  LightSlateGray  DarkMagenta|COUNT|MINUS
GH      Gray26  LightSlateGray  Seashell2|COUNT|PLUS
GH      Gray16  Burlywood1      Gray94|MULT|MINUS
GH      Gray26  Burlywood1      Gray55|MULT|MINUS
GH      Gray26  Burlywood1      Gray80|DIV|PLUS
GH      Gray26  Burlywood1      Chartreuse3|MULT|MINUS
GH      Gray89  Gray89  Gainsboro|MULT|PLUS
GH      Gray89  Gray89  Gray78|MULT|PLUS
GH      Gray89  Gray89  Moccasin|PLUS|DIV
GH      Gray89  Gray89  Gray99|PLUS|MINUS
GH      Gray89  DarkSlateGray3  Aquamarine4|DIV|MULT
GH      Gray89  LightGreen      Gray65|MULT|MINUS
GH      RosyBrown4      DarkCyan        PaleGreen4|COUNT|DIV
GH      RosyBrown4      DarkCyan        HotPink3|PLUS|DIV
GH      RosyBrown4      Ivory1  Ivory1|MULT|DIV
GH      RosyBrown4      Ivory1  Snow1|DIV|MULT
GH      RosyBrown4      Ivory1  DarkSalmon|COUNT|MULT
--
Jacqueline Landman Gay         |     jac...@hyperactivesw.com
HyperActive Software           |     http://www.hyperactivesw.com

_______________________________________________
use-livecode mailing list
use-livecode@lists.runrev.com
Please visit this url to subscribe, unsubscribe and manage your subscription 
preferences:
http://lists.runrev.com/mailman/listinfo/use-livecode

Reply via email to