質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Redis

Redisは、オープンソースのkey-valueデータストアで、NoSQLに分類されます。すべてのデータをメモリ上に保存するため、処理が極めて高速です。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

1525閲覧

pythonのtime関数を使用できません

hamazon

総合スコア16

Redis

Redisは、オープンソースのkey-valueデータストアで、NoSQLに分類されます。すべてのデータをメモリ上に保存するため、処理が極めて高速です。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2020/09/28 01:54

前提・実現したいこと

入門python3(オライリー・ジャパン)のp267において、time関数を用いてユーザのログインを監視するコードを書いていきます。その過程において、最初のユーザを追加したいです。正しく操作すれば以下のように返されます。

Python3

1>>> import time 2>>> now = time.time() 3>>> now 41601257294.666655 5>>> conn.zadd('logins', 'smeagol', now) 61

発生するエラー

以下のようにエラーが表示されます。ちなみにここではredisをimportした後にconnを定義してからtimeをimportしています。

該当のソースコード

Python3

1>>> import redis 2>>> conn = redis.Redis() 3>>> import time 4>>> now = time.time() 5>>> now 61601257294.666655 7>>> conn.zadd('logins', 'smeagol', now) 8Traceback (most recent call last): 9 File "<stdin>", line 1, in <module> 10 File "/Users/kota/.pyenv/versions/3.6.5/lib/python3.6/site-packages/redis/client.py", line 2685, in zadd 11 for pair in iteritems(mapping): 12 File "/Users/kota/.pyenv/versions/3.6.5/lib/python3.6/site-packages/redis/_compat.py", line 159, in iteritems 13 return iter(x.items()) 14AttributeError: 'str' object has no attribute 'items' 15

補足情報(FW/ツールのバージョンなど)

PCはMacを用いています。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

エラーが起きているのは conn.zadd です。

https://github.com/andymccurdy/redis-py#user-content-mset-msetnx-and-zadd

MSET, MSETNX and ZADD
(略)
To resolve this, redis-py 3.0 has changed these three commands to all accept a single positional argument named mapping that is expected to be a dict.

redis-py 3.0からインターフェースが変わったのでそのコードは動きません。
何よりも先に公式ドキュメントを見ることです。zaddでページ内検索すれば、Upgrading from redis-py 2.X to 3.0の中にZADDの項目が見つかります。

python

1conn.zadd('logins', {'smeagol': now})

でしょう。

投稿2020/09/28 02:13

quickquip

総合スコア11235

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hamazon

2020/09/28 03:38

ご回答ありがとうございます。 ご提示頂いた通りに操作すると以下のようにエラーが出てしまいます... >>> import redis >>> conn = redis.Redis() >>> import time >>> now = time.time() >>> now 1601264163.42672 >>> conn.zadd('logins', {'smeagol': now}) Traceback (most recent call last): File "<stdin>", line 1, in <module> File "/Users/kota/.pyenv/versions/3.6.5/lib/python3.6/site-packages/redis/client.py", line 2315, in zadd raise RedisError("ZADD requires an equal number of " redis.exceptions.RedisError: ZADD requires an equal number of values and scores もしこちらの原因も分かりましたら教えて頂けますと幸いです????‍♂️
quickquip

2020/09/28 04:19

このエラーは2.xにダウングレードして実行したからですね。
guest

0

ベストアンサー

Redisのバージョンを3未満に下げないとエラーが出ます。

入門Python3 正誤表 P267- オライリー本 BillLubanovic - Qiita

Redis >= 3.0.0 not working · Issue #197 · rq/rq-scheduler

追加分: おっと、その後GitHubのスレッドを追っていたら#198で解決されていたので、バージョンを下げるのではなく、zaddの書き方を(別の回答者の方が指摘しているように)変更してください。

Update zadd calls to redis-py 3 function signature by ericatkin · Pull Request #198 · rq/rq-scheduler

投稿2020/09/28 02:11

編集2020/09/28 02:17
Daregada

総合スコア11990

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hamazon

2020/09/28 03:32

ご回答ありがとうございます。 zaddの書き方を変更する方は理解できませんでしたが、はじめにご提示頂いたRedisのダウングレードで解決いたしました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問