foreach(n) - phpMan

Command: man perldoc info search(apropos)  


foreach(n)                            Tcl Built-In Commands                            foreach(n)



_________________________________________________________________________________________________

NAME
       foreach - Iterate over all elements in one or more lists

SYNOPSIS
       foreach varname list body
       foreach varlist1 list1 ?varlist2 list2 ...? body
_________________________________________________________________


DESCRIPTION
       The  foreach  command implements a loop where the loop variable(s) take on values from one
       or more lists.  In the simplest case there is one loop variable, varname,  and  one  list,
       list,  that  is a list of values to assign to varname.  The body argument is a Tcl script.
       For each element of list (in order from first to last), foreach assigns  the  contents  of
       the element to varname as if the lindex command had been used to extract the element, then
       calls the Tcl interpreter to execute body.

       In the general case there can be more than one value list (e.g.,  list1  and  list2),  and
       each  value  list  can  be  associated  with  a list of loop variables (e.g., varlist1 and
       varlist2).  During each iteration of the loop the variables of each varlist  are  assigned
       consecutive  values  from  the  corresponding list.  Values in each list are used in order
       from first to last, and each value is used exactly once.  The total number of loop  itera-
       tions  is large enough to use up all the values from all the value lists.  If a value list
       does not contain enough elements for each of its loop variables in each  iteration,  empty
       values are used for the missing elements.

       The  break  and continue statements may be invoked inside body, with the same effect as in
       the for command.  Foreach returns an empty string.

EXAMPLES
       This loop prints every value in a list together with the square and cube of the value:
              set values {1 3 5 7 2 4 6 8}  ;# Odd numbers first, for fun!
              puts "Value\tSquare\tCube"    ;# Neat-looking header
              foreach x $values {           ;# Now loop and print...
                  puts " $x\t [expr {$x**2}]\t [expr {$x**3}]"
              }

       The following loop uses i and j as loop variables to iterate over pairs of elements  of  a
       single list.
              set x {}
              foreach {i j} {a b c d e f} {
                  lappend x $j $i
              }
              # The value of x is "b a d c f e"
              # There are 3 iterations of the loop.

       The next loop uses i and j to iterate over two lists in parallel.
              set x {}
              foreach i {a b c} j {d e f g} {
                  lappend x $i $j
              }
              # The value of x is "a d b e c f {} g"
              # There are 4 iterations of the loop.

       The two forms are combined in the following example.
              set x {}
              foreach i {a b c} {j k} {d e f g} {
                  lappend x $i $j $k
              }
              # The value of x is "a d e b f g c {} {}"
              # There are 3 iterations of the loop.


SEE ALSO
       for(n), while(n), break(n), continue(n)


KEYWORDS
       foreach, iteration, list, looping



Tcl                                                                                    foreach(n)

Generated by $Id: phpMan.php,v 4.55 2007/09/05 04:42:51 chedong Exp $ Author: Che Dong
On Apache/2.4.6 (CentOS)
Under GNU General Public License
2025-01-09 19:59 @127.0.0.1 CrawledBy Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
Valid XHTML 1.0!Valid CSS!