Differences between revisions 1 and 22 (spanning 21 versions)
Revision 1 as of 2007-05-02 23:12:30
Size: 1376
Editor: redondos
Comment:
Revision 22 as of 2014-01-27 14:13:22
Size: 2336
Editor: host-2-99-128-84
Comment:
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
[[Anchor(faq25)]] <<Anchor(faq25)>>
Line 3: Line 4:
Use {{{${10} }}}instead of {{{$10}}}. This works for ["BASH"] and KornShell, but not for older BourneShell implementations. Another way to access arbitrary positional parameters after $9 is to use {{{for}}}, e.g. to get the last parameter: Use {{{${10} }}}instead of {{{$10}}}. This works for [[BASH]] and KornShell, but not for older BourneShell implementations. Another way to access arbitrary positional parameters after $9 is to use {{{for}}}, e.g. to get the last parameter:
Line 6: Line 7:
    # Bourne
Line 13: Line 15:
Line 17: Line 18:
    # Bourne
Line 21: Line 23:
        if [ $i -eq $n ]         if test $i -eq $n
Line 23: Line 25:
            argn=arg             argn=$arg
Line 30: Line 32:
Line 37: Line 38:
and can be put into a helpful function:
Line 38: Line 40:
Although direct access to any positional argument is possible this way, it's hardly needed. The common way is to use {{{getopts(3)}}} to process command line options (e.g. "-l", or "-o filename"), and then use either {{{for}}} or {{{while}}} to process all arguments in turn. An explanation of how to process command line arguments is available here: http://www.shelldorado.com/goodcoding/cmdargs.html {{{
    getarg() { # $1 is argno
        shift $1 && echo "$1"
    }
    arg12=$(getarg 12 "$@")
}}}
or to avoid the cost of a subshell, you can name the variable it should be written to:

{{{
    getargto() { # $1 is variable, $2 is argno
        local __="$1" && shift
        shift $1 && printf -v "$__" "$1"
    }
    getargto arg12 12 "$@"
}}}
In addition, bash and ksh93 treat the set of positional parameters as an [[BashFAQ/005|array]], and you may use [[BashFAQ/073|parameter expansion]] syntax to address those elements in a variety of ways:

{{{
    # Bash, ksh93
    for x in "${@:(-2)}" # iterate over the last 2 parameters
    for y in "${@:2}" # iterate over all parameters starting at $2
                            # which may be useful if we don't want to shift
}}}
Although direct access to any positional argument is possible this way, it's seldom needed. The common alternative is to use {{{getopts}}} to process options (e.g. "-l", or "-o filename"), and then use either {{{for}}} or {{{while}}} to process all the remaining arguments in turn. An explanation of how to process command line arguments is available in [[BashFAQ/035|FAQ #35]], and another is found at http://www.shelldorado.com/goodcoding/cmdargs.html

----
CategoryShell

How can I access positional parameters after $9?

Use ${10} instead of $10. This works for BASH and KornShell, but not for older BourneShell implementations. Another way to access arbitrary positional parameters after $9 is to use for, e.g. to get the last parameter:

    # Bourne
    for last
    do
        : # nothing
    done

    echo "last argument is: $last"

To get an argument by number, we can use a counter:

    # Bourne
    n=12        # This is the number of the argument we are interested in
    i=1
    for arg
    do
        if test $i -eq $n
        then
            argn=$arg
            break
        fi
        i=`expr $i + 1`
    done
    echo "argument number $n is: $argn"

This has the advantage of not "consuming" the arguments. If this is no problem, the shift command discards the first positional arguments:

    shift 11
    echo "the 12th argument is: $1"

and can be put into a helpful function:

    getarg() { # $1 is argno
        shift $1 && echo "$1"
    }
    arg12=$(getarg 12 "$@")

or to avoid the cost of a subshell, you can name the variable it should be written to:

    getargto() { # $1 is variable, $2 is argno
        local __="$1" && shift
        shift $1 && printf -v "$__" "$1"
    }
    getargto arg12 12 "$@"

In addition, bash and ksh93 treat the set of positional parameters as an array, and you may use parameter expansion syntax to address those elements in a variety of ways:

    # Bash, ksh93
    for x in "${@:(-2)}"    # iterate over the last 2 parameters
    for y in "${@:2}"       # iterate over all parameters starting at $2
                            # which may be useful if we don't want to shift

Although direct access to any positional argument is possible this way, it's seldom needed. The common alternative is to use getopts to process options (e.g. "-l", or "-o filename"), and then use either for or while to process all the remaining arguments in turn. An explanation of how to process command line arguments is available in FAQ #35, and another is found at http://www.shelldorado.com/goodcoding/cmdargs.html


CategoryShell

BashFAQ/025 (last edited 2024-03-28 14:56:51 by emanuele6)