Python实现的简单hangman游戏实例
本文实例讲述了Python实现的简单hangman游戏。分享给大家供大家参考。具体如下:
#!/usr/bin/env python import random import cPickle class Hangman(object): '''A simple hangman game that tries to improve your vocabulary a bit ''' def __init__(self): # the variables used, this is not necessary self.dumpfile = '' #the dictionary file self.dictionary = {} #the pickled dict self.words = [] #list of words used self.secret_word = '' #the 'key' self.length = 0 #length of the 'key' self.keys = [] #inputs that match the 'key' self.used_keys = [] #keys that are already used self.guess = '' #player's guess self.mistakes = 0 #number of incorrect inputs return self.load_dict() #insert some random hints for the player def insert_random(self, length): randint = random.randint # 3 hints if length >= 7: hint = 3 else: hint = 1 for x in xrange(hint): a = randint(1, length - 1) self.keys[a-1] = self.secret_word[a-1] def test_input(self): #if the guessed letter matches if self.guess in self.secret_word: indexes = [i for i, item in enumerate(self.secret_word) if item == self.guess] for index in indexes: self.keys[index] = self.guess self.used_keys.append(self.guess) print "used letters ",set(self.used_keys),'\n' #if the guessed letter didn't match else: self.used_keys.append(self.guess) self.mistakes += 1 print "used letters ",set(self.used_keys),'\n' # load the pickled word dictionary and unpickle them def load_dict(self): try : self.dumpfile = open("~/python/hangman/wordsdict.pkl", "r") except IOError: print "Couldn't find the file 'wordsdict.pkl'" quit() self.dictionary = cPickle.load(self.dumpfile) self.words = self.dictionary.keys() self.dumpfile.close() return self.prepare_word() #randomly choose a word for the challenge def prepare_word(self): self.secret_word = random.choice(self.words) #don't count trailing spaces self.length = len(self.secret_word.rstrip()) self.keys = ['_' for x in xrange(self.length)] self.insert_random(self.length) return self.ask() #display the challenge def ask(self): print ' '.join(self.keys), ":", self.dictionary[self.secret_word] print return self.input_loop() #take input from the player def input_loop(self): #four self.mistakes are allowed chances = len(set(self.secret_word)) + 4 while chances != 0 and self.mistakes < 5: try: self.guess = raw_input("> ") except EOFError: exit(1) self.test_input() print ' '.join(self.keys) if '_' not in self.keys: print 'well done!' break chances -= 1 if self.mistakes > 4: print 'the word was', ''.join(self.secret_word).upper() return self.quit_message() def quit_message(self): print "\n" print "Press 'c' to continue, or any other key to quit the game. " print "You can always quit the game by pressing 'Ctrl+D'" try: command = raw_input('> ') if command == 'c': return self.__init__() #loopback else : exit(0) except EOFError: exit(1) if __name__ == '__main__': game = Hangman() game.__init__()
希望本文所述对大家的Python程序设计有所帮助。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









hadidb:軽量で高レベルのスケーラブルなPythonデータベースHadIDB(HadIDB)は、Pythonで記述された軽量データベースで、スケーラビリティが高くなっています。 PIPインストールを使用してHADIDBをインストールする:PIPINSTALLHADIDBユーザー管理CREATEユーザー:CREATEUSER()メソッド新しいユーザーを作成します。 Authentication()メソッドは、ユーザーのIDを認証します。 fromhadidb.operationimportuseruser_obj = user( "admin"、 "admin")user_obj。

2時間以内にPythonの基本的なプログラミングの概念とスキルを学ぶことができます。 1.変数とデータ型、2。マスターコントロールフロー(条件付きステートメントとループ)、3。機能の定義と使用を理解する4。

Hash値として保存されているため、Navicatを介してMongoDBパスワードを直接表示することは不可能です。紛失したパスワードを取得する方法:1。パスワードのリセット。 2。構成ファイルを確認します(ハッシュ値が含まれる場合があります)。 3.コードを確認します(パスワードをハードコードできます)。

Pythonは、Web開発、データサイエンス、機械学習、自動化、スクリプトの分野で広く使用されています。 1)Web開発では、DjangoおよびFlask Frameworksが開発プロセスを簡素化します。 2)データサイエンスと機械学習の分野では、Numpy、Pandas、Scikit-Learn、Tensorflowライブラリが強力なサポートを提供します。 3)自動化とスクリプトの観点から、Pythonは自動テストやシステム管理などのタスクに適しています。

MySQLデータベースパフォーマンス最適化ガイドリソース集約型アプリケーションでは、MySQLデータベースが重要な役割を果たし、大規模なトランザクションの管理を担当しています。ただし、アプリケーションのスケールが拡大すると、データベースパフォーマンスのボトルネックが制約になることがよくあります。この記事では、一連の効果的なMySQLパフォーマンス最適化戦略を検討して、アプリケーションが高負荷の下で効率的で応答性の高いままであることを保証します。実際のケースを組み合わせて、インデックス作成、クエリ最適化、データベース設計、キャッシュなどの詳細な主要なテクノロジーを説明します。 1.データベースアーキテクチャの設計と最適化されたデータベースアーキテクチャは、MySQLパフォーマンスの最適化の基礎です。いくつかのコア原則は次のとおりです。適切なデータ型を選択し、ニーズを満たす最小のデータ型を選択すると、ストレージスペースを節約するだけでなく、データ処理速度を向上させることもできます。

データの専門家として、さまざまなソースから大量のデータを処理する必要があります。これは、データ管理と分析に課題をもたらす可能性があります。幸いなことに、AWS GlueとAmazon Athenaの2つのAWSサービスが役立ちます。

Redisサーバーを起動する手順には、以下が含まれます。オペレーティングシステムに従ってRedisをインストールします。 Redis-Server(Linux/Macos)またはRedis-Server.exe(Windows)を介してRedisサービスを開始します。 Redis-Cli ping(Linux/macos)またはRedis-Cli.exePing(Windows)コマンドを使用して、サービスステータスを確認します。 Redis-Cli、Python、node.jsなどのRedisクライアントを使用して、サーバーにアクセスします。

Redisのキューを読むには、キュー名を取得し、LPOPコマンドを使用して要素を読み、空のキューを処理する必要があります。特定の手順は次のとおりです。キュー名を取得します:「キュー:キュー」などの「キュー:」のプレフィックスで名前を付けます。 LPOPコマンドを使用します。キューのヘッドから要素を排出し、LPOP Queue:My-Queueなどの値を返します。空のキューの処理:キューが空の場合、LPOPはnilを返し、要素を読む前にキューが存在するかどうかを確認できます。
