Maybe some' like this?

```
>>>inp = ("hello", "my", "friend")
>>>out = tuple([i == 1 and x.upper() or x for (x,i) in zip(t,range(len(t)))])
>>> out
('hello', 'MY', 'friend')
```

Note: rather than `(x,i) in zip(t, range(len(t)))`

I should have thought of using the enumerate function : `(i,x) in enumerate(t)`

Making it a bit more general:

Rather than hard-coding the 1, we can place it in a variable.

Also, by using a tuple for that purpose, we can apply the function to elements at multiple indexes.

```
>>>inp = ("hello", "my", "friend")
>>>ix = (0,2)
>>>out = tuple([i in ix and x.upper() or x for (i, x) in enumerate(t)])
>>> out
('HELLO', 'my', 'FRIEND')
```

Also, we can "replace" the zip()/enumerate() by map(), in something like

```
out = tuple(map(lambda x,i : i == 1 and x.upper() or x, inp, range(len(inp)) ) )
```

Edit: (addressing comment about specifying the function to apply):

Could be something as simple as:

```
>>> f = str.upper # or whatever function taking a single argument
>>> out = tuple(map(lambda x,i : i == 1 and f(x) or x, inp, range(len(inp)) ) )
```

Since we're talking about applying *any* function, we should mention the small caveat with the `condition and if_true or if_false`

construct which is not *exactly* a substitute for the if/else ternary operator found in other languages. The limitation is that the function cannot return a value which is equivalent to False (None, 0, 0.0, '' for example). A suggestion to avoid this problem, is, with Python 2.5 and up, to use the true if-else ternary operator, as shown in Dave Kirby's answer (note the `when_true if condition else when_false`

syntax of this operator)