MathGroup Archive 2006

[Date Index] [Thread Index] [Author Index]

Search the Archive

Re: Selecting table rows


Skirmantas wrote:
> I have a 2D-table whose first column contains the unique identifiers (ID) of each row (IDs can be any numbers). I need to delete all rows whose IDs are not members of another, control list.
> 
> The following works, but I'm wondering if there is a shorter way to do this.
> 
> TBL = {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}, {13, 14, 15, 16}, {17, 18, 19, 20}};
> 
> CNTR = {1, 9, 17};
> 
> Map[Part[TBL, #]&, Flatten[Map[Position[Transpose[TBL][[1]], #]&, CNTR]]]
>   
> Thanks --
> 
> Skirmantas
> 
Hi Skirmantas,

You could use the built-in function *Select*. For instance,

In[1]:=
TBL = {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12},
     {13, 14, 15, 16}, {17, 18, 19, 20}};

In[2]:=
CNTR = {1, 9, 17};

In[3]:=
Select[TBL, MemberQ[CNTR, #1[[1]]] & ]

Out[3]=
{{1, 2, 3, 4}, {9, 10, 11, 12}, {17, 18, 19, 20}}

Best regards,
Jean-Marc


  • Prev by Date: a way to escape strings for export
  • Next by Date: Image Processing
  • Previous by thread: Re: Selecting table rows
  • Next by thread: Re: Selecting table rows