在Python中有效交换列表元素

时间:2018-11-09 06:21:27

标签: python list vectorization

我有如下的Python列表:-

l=['EUR/USD',
 'USD/JPY',
 'GBP/USD',
 'USD/CAD',
 'AUD/USD',
 'NZD/USD',
 'USD/CHF',
 'USD/NOK',
 'USD/SEK']

我希望基准货币为美元。这意味着l的第一个元素将是USD/EUR。以下代码可以正常工作,但我想知道是否还有更好的方法。

l2=[]
for x in range(len(l)):
    l2.append(l[x].split('/'))

k=pd.DataFrame(l2)

for i in range(len(k)):

    if k.iloc[i,0]=='USD':
        print("base currency is USD")

    else:
        print("Base currency is not USD. Making it base currency")
        temp=k.iloc[i,0]
        k.iloc[i,0]='USD'
        k.iloc[i,1]=temp

3 个答案:

答案 0 :(得分:4)

我会这样写,这使IMO更具可读性。

>>> l=['EUR/USD', 'USD/JPY', 'GBP/USD', 'USD/CAD', 'AUD/USD', 'NZD/USD', 'USD/CHF', 'USD/NOK', 'USD/SEK']
>>>
>>> result = []
>>> delim = '/'
>>> for currencies in l:
...:    first, second = currencies.split(delim)
...:    if first == 'USD':
...:        result.append(currencies)
...:    else:
...:        result.append(delim.join((second, first)))
...:        
>>> result
>>> 
['USD/EUR',
 'USD/JPY',
 'USD/GBP',
 'USD/CAD',
 'USD/AUD',
 'USD/NZD',
 'USD/CHF',
 'USD/NOK',
 'USD/SEK']

作为一般性提示,避免像瘟疫一样在迭代时避免使用显式索引。通常,比用整数索引数据结构(当然,并非总是如此)更具可读性。

这是一个很酷的视频:Loop like a native: while, for, iterators, generators

答案 1 :(得分:2)

定义一个函数以反转对,然后使用map

In [759]: def usd_base(ccy):
     ...:     delimiter = '/'
     ...:     base, term = ccy.split(delimiter)
     ...:     if base != 'USD' and term == 'USD':
     ...:         return delimiter.join((term, base))
     ...:     return ccy
     ...:

In [760]: list(map(usd_base, l))
Out[760]:
['USD/EUR',
 'USD/JPY',
 'USD/GBP',
 'USD/CAD',
 'USD/AUD',
 'USD/NZD',
 'USD/CHF',
 'USD/NOK',
 'USD/SEK']

如果您尚未使用DataFrame,则可能没有必要为此目的list创建一个

对于Python 2,您可以使用

map(usd_base, l)

答案 2 :(得分:2)

您可以使用sort(b, b+10, [a](int i, int j){ return a[i] > a[j]; }); + endswith + split

存档
join

结果

['/'.join(i.split('/')[::-1]) if i.endswith('USD') else i for i in l]