[解決済み] リストの順番を維持したまま、重複を削除するにはどうしたらいいですか?
質問
Pythonのリストから、順序を維持したまま重複を削除するビルトインはありますか?私は、重複を削除するためにセットを使用することができることを知っているが、それは元の順序を破壊する。私はまた、このように自分自身をロールバックすることができることを知っています。
def uniq(input):
output = []
for x in input:
if x not in output:
output.append(x)
return output
(ありがとうございます 巻き戻し そのために コードサンプル .)
でも、できればビルトインやもっとPythonicなイディオムを役立てたいですね。
関連する質問 Pythonでは、すべての要素が一意であるように、リストから重複を削除するための最速のアルゴリズムは何ですか? 順序を維持しながら ?
解決方法は?
ここでは、いくつかの選択肢をご紹介します。 http://www.peterbe.com/plog/uniqifiers-benchmark
最速の1枚。
def f7(seq):
seen = set()
seen_add = seen.add
return [x for x in seq if not (x in seen or seen_add(x))]
なぜ
seen.add
に
seen_add
を呼び出すのではなく、単に
seen.add
? Python は動的な言語であり、そのために
seen.add
は、ローカル変数を解決するよりもコストがかかります。
seen.add
ランタイムはそれを除外できるほど賢くない。安全策を講じるために、毎回オブジェクトをチェックしなければならないのです。
もし、同じデータセットでこの関数を何度も使うつもりなら、順序付きセットの方がいいかもしれません。 http://code.activestate.com/recipes/528878/
O (1)1回の操作で挿入、削除、メンバーチェックを行う。
(小さな追記
seen.add()
は常に
None
というように
or
は、セットの更新を試みる方法としてのみ存在し、論理テストの不可欠な部分としては存在しない)。
関連
-
[解決済み] データ型が理解できない
-
[解決済み] リストのリストからフラットなリストを作るには?
-
[解決済み] リストが空かどうかを確認するにはどうすればよいですか?
-
[解決済み] 割り当て後にリストが予期せず変更されました。その理由と防止策を教えてください。
-
[解決済み] リストを均等な大きさの塊に分割するには?
-
[解決済み] リストの最後の要素を取得する方法
-
[解決済み] JavaScriptの配列で一意な値をすべて取得する(重複を排除する)。
-
[解決済み] リストの要素数を取得する方法
-
[解決済み] リストからランダムに項目を選択するにはどうすればよいですか?
-
[解決済み] インデックスを指定してリストから要素を削除する方法
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
pythonを使ったオフィス自動化コード例
-
Python jiabaライブラリの使用方法について説明
-
python implement mysql add delete check change サンプルコード
-
Python百行で韓服サークルの画像クロールを実現する
-
[解決済み】「RuntimeError: dictionary changed size during iteration」エラーを回避する方法とは?
-
[解決済み] データ型が理解できない
-
[解決済み】Pythonでgoogle APIのJSONコードを読み込むとエラーになる件
-
[解決済み】IndexError: invalid index to scalar variableを修正する方法
-
[解決済み】ValueError: pickleプロトコルがサポートされていません。3、python2 pickleはpython3 pickleでダンプしたファイルを読み込むことができない?
-
[解決済み】NameError: 名前 'self' が定義されていません。