Python 初心者がよく遭遇する 17 のエラーの分析
1) if 、 elif 、 else 、 for 、 while 、 class 、 def ステートメントの最後に : を追加するのを忘れました (「SyntaxError: 無効な構文」が発生します)
このエラーは、次のようなコードで発生します:
if spam== 42 print('Hello!')
2) == の代わりに = を使用します (「SyntaxError: 無効な構文」が発生します)
= は代入演算子、== は等価比較演算子です。次のコードでエラーが発生します:
if spam= 42: print('Hello!')
3) インデントの間違った使用。 (「IndentationError: 予期しないインデント」、「IndentationError: unindent is not match any external indetation level」、および「IndentationError: Expected an indented block」が発生します)
インデントの増加は: で終わるステートメントの後にのみ使用され、その後は以前のインデント形式を復元する必要があることに注意してください。次のコードでエラーが発生します:
print('Hello!') print('Howdy!') 或者: if spam== 42: print('Hello!') print('Howdy!') 或者: if spam== 42: print('Hello!')
4) for ループ ステートメントで len() を呼び出すのを忘れました (「TypeError: 'list' オブジェクトを整数として解釈できません」という結果になります)
通常、インデックスによってリストまたは文字列の要素を反復処理する必要があり、これには range() 関数を呼び出す必要があります。リストの代わりに len 値を返すようにしてください。
次のコードでエラーが発生します:
spam= ['cat','dog','mouse'] for iin range(spam): print(spam[i])
5) 文字列の値を変更してみます (「TypeError: 'str' オブジェクトは項目の割り当てをサポートしていません」という結果になります)
string は不変のデータ型です。このエラーは次のコードで発生します:
spam= 'I have a pet cat.' spam[13]= 'r' print(spam)
そして実際にこれをやりたいとします:
spam= 'I have a pet cat.' spam= spam[:13]+ 'r' + spam[14:] print(spam)
6) 文字列以外の値を文字列と連結しようとします (「TypeError: 'int' オブジェクトを暗黙的に str に変換できません」という結果になります)
次のコードでエラーが発生します:
numEggs= 12 print('I have ' + numEggs+ ' eggs.')
そして実際にこれをやりたいとします:
numEggs= 12 print('I have ' + str(numEggs)+ ' eggs.') 或者: numEggs= 12 print('I have %s eggs.' % (numEggs))
7) 文字列の先頭と末尾に引用符を追加するのを忘れました (結果として「SyntaxError: EOL while scan string literal」が発生します)
次のコードでエラーが発生します:
print(Hello!') 或者: print('Hello!) 或者: myName= 'Al' print('My name is ' + myName+ . How are you?')
8) 変数または関数名のスペルが間違っています (「名前エラー: 名前 'foaba' が定義されていません」という結果になります)
次のコードでエラーが発生します:
foobar= 'Al' print('My name is ' + fooba) 或者: spam= ruond(4.2) 或者: spam= Round(4.2)
9) メソッド名のスペルが間違っています (「AttributeError: 'str' object has no attribute ' lowerr'」という結果になります)
次のコードでエラーが発生します:
spam= 'THIS IS IN LOWERCASE.' spam= spam.lowerr()
10) 参照がリストの最大インデックスを超えています (「IndexError: リスト インデックスが範囲外です」が発生します)
次のコードでエラーが発生します:
spam= ['cat','dog','mouse'] print(spam[6])
11) 存在しない辞書キーを使用する (「KeyError: 'spam'」が発生する)
次のコードでエラーが発生します:
spam= {'cat':'Zophie','dog':'Basil','mouse':'Whiskers'} print('The name of my pet zebra is ' + spam['zebra'])
12) 変数名として Python キーワードを使用してみてください (「SyntaxError: 無効な構文」が発生します)
Python キーは変数名として使用できません。このエラーは次のコードで発生します:
クラス = '代数'
Python3 のキーワードは、and、as、assert、break、class、 continue、def、del、elif、else、excel、False、finally、for、from、global、if、import、in、is、lambda、None、非ローカル、not、or、pass、raise、return、True、try、while、with、yield
13) 定義された新しい変数でインクリメント演算子を使用する (「NameError: 名前 'foobar' が定義されていません」という結果になります)
変数を宣言するときは、初期値として 0 または空の文字列を使用しないでください。このように、インクリメント演算子を使用した文 spam += 1 は spam = spam + 1 と等しくなります。これは、spam が指定する必要があることを意味します。有効な初期値。
次のコードでエラーが発生します:
spam= 0 spam+= 42 eggs+= 42
14) ローカル変数を定義する前に関数内でローカル変数を使用します (ローカル変数と同じ名前のグローバル変数があります) (結果として「UnboundLocalError: local variable 'foobar' Referenced before assigning」が発生します)
同じ名前のグローバル変数がある場合、関数内でローカル変数を使用するのは非常に複雑です。使用規則は、関数内で何かが定義されている場合、関数内でのみ使用される場合です。その反対はグローバル変数です。
これは、定義する前に関数内でグローバル変数として使用できないことを意味します。
次のコードでエラーが発生します:
someVar= 42 def myFunction(): print(someVar) someVar= 100 myFunction()
15) range() を使用して整数のリストを作成してみてください (「TypeError: 'range' オブジェクトは項目の割り当てをサポートしていません」という結果になります)
整数の順序付きリストを取得したい場合があるため、このリストを生成するには range() が良い方法のように思えます。ただし、 range() は実際のリスト値ではなく、「範囲オブジェクト」を返すことに注意する必要があります。
次のコードでエラーが発生します:
spam= range(10) spam[4]= -1
おそらくこれがあなたがやりたいことです:
spam= list(range(10)) spam[4]= -1
(注: spam = range(10) は、Python 2 では range() がリスト値を返すため機能しますが、Python 3 では上記のエラーが発生します)
16) 良いアイデアは、++ または -- インクリメント演算子とデクリメント演算子です。 (「SyntaxError: 無効な構文」が発生します)
如果你习惯于例如 C++ , Java , PHP 等其他的语言,也许你会想要尝试使用 ++ 或者 -- 自增自减一个变量。在Python中是没有这样的操作符的。
该错误发生在如下代码中:
spam= 1 spam++
也许这才是你想做的:
spam= 1 spam+= 1
17)忘记为方法的第一个参数添加self参数(导致“TypeError: myMethod() takes no arguments (1 given)”)
该错误发生在如下代码中:
class Foo(): def myMethod(): print('Hello!') a= Foo() a.myMethod()

ホット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)

ホットトピック









PSの「読み込み」の問題は、リソースアクセスまたは処理の問題によって引き起こされます。ハードディスクの読み取り速度は遅いか悪いです。CrystaldiskInfoを使用して、ハードディスクの健康を確認し、問題のあるハードディスクを置き換えます。不十分なメモリ:高解像度の画像と複雑な層処理に対するPSのニーズを満たすためのメモリをアップグレードします。グラフィックカードドライバーは時代遅れまたは破損しています:ドライバーを更新して、PSとグラフィックスカードの間の通信を最適化します。ファイルパスが長すぎるか、ファイル名に特殊文字があります。短いパスを使用して特殊文字を避けます。 PS独自の問題:PSインストーラーを再インストールまたは修理します。

ブートがさまざまな理由によって引き起こされる可能性がある場合、「読み込み」に巻き込まれたPS:腐敗したプラグインまたは競合するプラグインを無効にします。破損した構成ファイルの削除または名前変更。不十分なプログラムを閉じたり、メモリをアップグレードしたりして、メモリが不十分であることを避けます。ソリッドステートドライブにアップグレードして、ハードドライブの読み取りをスピードアップします。 PSを再インストールして、破損したシステムファイルまたはインストールパッケージの問題を修復します。エラーログ分析の起動プロセス中にエラー情報を表示します。

「ロード」は、PSでファイルを開くときに発生します。理由には、ファイルが大きすぎるか破損しているか、メモリが不十分で、ハードディスクの速度が遅い、グラフィックカードドライバーの問題、PSバージョンまたはプラグインの競合が含まれます。ソリューションは、ファイルのサイズと整合性を確認し、メモリの増加、ハードディスクのアップグレード、グラフィックカードドライバーの更新、不審なプラグインをアンインストールまたは無効にし、PSを再インストールします。この問題は、PSパフォーマンス設定を徐々にチェックして使用し、優れたファイル管理習慣を開発することにより、効果的に解決できます。

この記事では、MySQLデータベースの操作を紹介します。まず、MySQLWorkBenchやコマンドラインクライアントなど、MySQLクライアントをインストールする必要があります。 1. mysql-uroot-pコマンドを使用してサーバーに接続し、ルートアカウントパスワードでログインします。 2。CreatedAtaBaseを使用してデータベースを作成し、データベースを選択します。 3. createTableを使用してテーブルを作成し、フィールドとデータ型を定義します。 4. INSERTINTOを使用してデータを挿入し、データをクエリし、更新することでデータを更新し、削除してデータを削除します。これらの手順を習得することによってのみ、一般的な問題に対処することを学び、データベースのパフォーマンスを最適化することでMySQLを効率的に使用できます。

羽毛の鍵は、その漸進的な性質を理解することです。 PS自体は、勾配曲線を直接制御するオプションを提供しませんが、複数の羽毛、マッチングマスク、および細かい選択により、半径と勾配の柔らかさを柔軟に調整して、自然な遷移効果を実現できます。

MySQLには、無料のコミュニティバージョンと有料エンタープライズバージョンがあります。コミュニティバージョンは無料で使用および変更できますが、サポートは制限されており、安定性要件が低く、技術的な能力が強いアプリケーションに適しています。 Enterprise Editionは、安定した信頼性の高い高性能データベースを必要とするアプリケーションに対する包括的な商業サポートを提供し、サポートの支払いを喜んでいます。バージョンを選択する際に考慮される要因には、アプリケーションの重要性、予算編成、技術スキルが含まれます。完璧なオプションはなく、最も適切なオプションのみであり、特定の状況に応じて慎重に選択する必要があります。

MySQLパフォーマンスの最適化は、インストール構成、インデックス作成、クエリの最適化、監視、チューニングの3つの側面から開始する必要があります。 1。インストール後、INNODB_BUFFER_POOL_SIZEパラメーターやclose query_cache_sizeなど、サーバーの構成に従ってmy.cnfファイルを調整する必要があります。 2。過度のインデックスを回避するための適切なインデックスを作成し、説明コマンドを使用して実行計画を分析するなど、クエリステートメントを最適化します。 3. MySQL独自の監視ツール(ShowProcessList、ShowStatus)を使用して、データベースの健康を監視し、定期的にデータベースをバックアップして整理します。これらの手順を継続的に最適化することによってのみ、MySQLデータベースのパフォーマンスを改善できます。

PSカードの読み込みインターフェイスは、ソフトウェア自体(ファイルの破損またはプラグインの競合)、システム環境(ドライバーまたはシステムファイルの破損)、またはハードウェア(ハードディスクの破損またはメモリスティックの障害)によって引き起こされる場合があります。まず、コンピューターリソースで十分かどうかを確認し、バックグラウンドプログラムを閉じ、メモリとCPUリソースをリリースします。 PSのインストールを修正するか、プラグインの互換性の問題を確認してください。 PSバージョンを更新またはフォールバックします。グラフィックカードドライバーをチェックして更新し、システムファイルチェックを実行します。上記の問題をトラブルシューティングする場合は、ハードディスク検出とメモリテストを試すことができます。
