for k,v in targets.iteritems():
price= str(v['stockprice'])
Bids = str(u''.join(v['OtherBids']))
Bids = Bids.split(',')
# create a list of unique bids by ranking
for a, b in Zip(float(price), Bids):
try:
del b[next(i for i, e in enumerate(b) if format(e, '.4f') == a)]
except StopIteration:
pass
辞書からデータを抽出していますが、すべてUnicodeであるようです。どうすればユニコードのナンセンスを取り除くことができますか?
私はあなたのコードがあなたにエラーメッセージを与えていると思います、TypeError:Zip引数#1は反復をサポートしなければなりません。式Zip(float(price), Bids)
が原因でこのエラーが発生しています。この簡略化されたコードはエラーを示しています。
_>>> price = str(u'12.3456')
>>> bids = ['1.0', '2.0']
>>> Zip(float(price), bids)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: Zip argument #1 must support iteration
_
Python 2.x Zip()
組み込みライブラリ関数 は、すべての引数が反復可能である必要があります。 float(price)
は反復可能ではありません。
float(price)
を配列Bids
の各要素と組み合わせてタプルを作成する場合は、最初の引数式で itertools.repeat()
を使用できます。
_>>> import itertools
>>> price = str(u'12.3456')
>>> bids = ['1.0', '2.0']
>>> Zip(itertools.repeat(float(price),len(bids)), bids)
[(12.345599999999999, '1.0'), (12.345599999999999, '2.0')]
_
Unicodeデータ型の使用がTypeError
と関係があるとは思いません。