我有如下的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
答案 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]