举例讲解Python面相对象编程中对象的属性与类的方法
python 对象的属性
进入正题,来看一个实例来了解python中类,对象中公有属性,私有属性及局部变量,全局变量的区别.
root@10.1.6.200:~# cat object.py
#!/usr/bin/env python #coding:utf8 class Dave(): var1 = "class atribute,public atrribute var1" #类属性,公有属性var1 __var2 = "class self atribute __var2" #类的私有属性__var2 def fun(self): self.var2 = "object public atrribute var2" #对象的公有属性var2 self.__var3 = "object self atrribute __var3" #对象的私有属性__var3 var4 = "Function of the local variable var4" #函数fun的局部变量 def other(self): print self.__var3
根据上面代码后面加入以下代码可以实例化一个对象及获取类公有属性.
he = Dave() #实例化一个对象he print he.var1 #从实例中获取类的公有属性 print Dave.var1 #直接从类中获取公有属性
root@10.1.6.200:~# ./object.py
class atribute,public atrribute var1 class atribute,public atrribute var1
类的私有属性不能被类或对象直接调用
he = Dave() print Dave.__var2 print he.__var2
root@10.1.6.200:~# ./object.py
Traceback (most recent call last): File "./object.py", line 19, in <module> print Dave.__var2 AttributeError: class Dave has no attribute '__var2'
但可以通过方法间接调用.
class Dave(): var1 = "class atribute,public atrribute var1" #类属性,公有属性var1 __var2 = "class self atribute __var2" #类的私有属性__var2 def other(self): print Dave.__var2 he = Dave() he.other()
root@10.1.6.200:~# ./object.py
class self atribute __var2
获取类方法中的对象的公有属性,需要先通过对象执行类中的方法.并通过对象调用该属性.
he = Dave() liu = Dave() he.fun() print he.var2 print liu.var2
root@10.1.6.200:~# ./object.py
object public atrribute var2 Traceback (most recent call last): <span></span> #对象liu由于没有调用fun方法所有就没有该属性. File "./object.py", line 20, in <module> print liu.var2 AttributeError: Dave instance has no attribute 'var2'
对象的私有属性和类的私有属性类似,也不能被类或对象直接调用
he = Dave() he.fun() print he.__var3
root@10.1.6.200:~# ./object.py
Traceback (most recent call last): File "./object.py", line 18, in <module> print he.__var3 AttributeError: Dave instance has no attribute '__var3'
局部变量也不能被对象直接调用,可以在函数内部使用.
he = Dave() he.fun() print he.var4
root@10.1.6.200:~# ./object.py
Traceback (most recent call last): File "./object.py", line 18, in <module> print he.var4 AttributeError: Dave instance has no attribute 'var4'
def fun(self): self.var2 = "object public atrribute var2" #对象的公有属性var2 self.__var3 = "object self atrribute __var3" #对象的私有属性__var3 var4 = "Function of the local variable var4" #函数fun的局部变量 print var4 #可以在函数内部直接打印,只在该函数内有用 print self.__var3 he = Dave() he.fun()
root@10.1.6.200:~# ./object.py
Function of the local variable var4 object self atrribute __var3
那么var4和self._var3有什么区别呢.目前看2个都在外部使用不了.下面在定义一个函数other调用.
def fun(self): self.var2 = "object public atrribute var2" #对象的公有属性var2 self.__var3 = "object self atrribute __var3" #对象的私有属性__var3 var4 = "Function of the local variable var4" #函数fun的局部变量 print var4 #一个函数的局部变量在另外一个函数是访问不到的 print self.__var3 def other(self): print var4 print self.__var3 he = Dave() he.fun() print "#"*100 he.other()
root@10.1.6.200:~# ./object.py
Function of the local variable var4 object self atrribute __var3 #################################################################################################### Traceback (most recent call last): #会认为var4是全局变量打印.定义全局变量可在class 头加入 var4 = "global" File "./object.py", line 22, in <module> he.other() File "./object.py", line 16, in other print var4 NameError: global name 'var4' is not defined
#!/usr/bin/env python #coding:utf8 var4 = "global" #定义var4为全局变量 class Dave(): var1 = "class atribute,public atrribute var1" #类属性,公有属性var1 __var2 = "class self atribute __var2" #类的私有属性__var2 def fun(self): self.var2 = "object public atrribute var2" #对象的公有属性var2 self.__var3 = "object self atrribute __var3" #对象的私有属性__var3 var4 = "Function of the local variable var4" #函数fun的局部变量 print var4 print self.__var3 def other(self): print var4 print self.__var3 #可调用私有属性,前提是先调用fun he = Dave() he.fun() print "#"*100 he.other()
root@10.1.6.200:~# ./object.py
Function of the local variable var4 object self atrribute __var3 #################################################################################################### global object self atrribute __var3
python 类的方法
python类中的方法:公有方法,私有方法,类方法,静态方法.
下面通过一个实例了解它们之间的区别:
#!/usr/bin/env python #coding:utf8 class Dave(): name = "python" def fun1(self): #定义公有方法 print self.name print "i am public method" def __fun2(self): #定义私有方法 print self.name print "i am self method"
先来看公有方法和私有方法,加入以下代码输出
root@10.1.6.200:~# ./method.py #直接调用对象公有方法没有问题
python i am public method
私有方法和私有属性一样是被保护起来,不能直接调用对象的私有方法,但可以间接调用.
#!/usr/bin/env python #coding:utf8 class Dave(): name = "python" def fun1(self): #定义公有方法 print self.name print "i am public method" self.__fun2() def __fun2(self): #定义私有方法 print self.name print "i am self method" he = Dave() he.fun1()
root@10.1.6.200:~# ./method.py
python i am public method python i am self method
公有属性是可以被类调用,但是公有方法是不可以被类直接调用.需要实例化对象调用.如果想一个方法被类直接调用的话,就需要转换,变成一个类方法.变成类方法有2种,比较简单的可以加装饰器.
@classmethod def classFun(self): #定义类方法 print self.name print "i am class method" Dave.classFun()
root@10.1.6.200:~# ./method.py
python i am class method
另一个方法比较麻烦,需要定义一个新的函数,以及使用classmethod方法转换函数为类方法.当然调用也需要使用新的该函数名字.
def classFun(self): #定义类方法 print self.name print "i am class method" classnewFun = classmethod(classFun) Dave.classnewFun() #被转换后的是一个类方法,原来classfun还是一个普通方法
root@10.1.6.200:~# ./method.py
python i am class method
静态方法在使用中和类方法一样,也是为了让类中直接调用,区别定义时不加self.
@staticmethod def staticFun(): #d定义静态方法 print Dave.name #注意不加self,直接打name也不行,会认为调用全局变量,需要使用类型加属性. print "i am static method" Dave.staticFun()
oot@10.1.6.200:~# ./method.py
python i am static method
同样也可以通过一个函数调用
def staticfun(): #定义静态方法 print Dave.name print "i am static method" staticnewFun = staticmethod(staticFun) Dave.staticnewFun()
root@10.1.6.200:~# ./method.py
python i am static method

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

ホットトピック









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

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

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

MySQLは、基本的なデータストレージと管理のためにネットワーク接続なしで実行できます。ただし、他のシステムとのやり取り、リモートアクセス、または複製やクラスタリングなどの高度な機能を使用するには、ネットワーク接続が必要です。さらに、セキュリティ対策(ファイアウォールなど)、パフォーマンスの最適化(適切なネットワーク接続を選択)、およびデータバックアップは、インターネットに接続するために重要です。

MySQL接続は、次の理由が原因である可能性があります。MySQLサービスは開始されず、ファイアウォールは接続をインターセプトし、ポート番号が間違っています。ユーザー名またはパスワードが間違っています。My.cnfのリスニングアドレスは不適切に構成されています。トラブルシューティング手順には以下が含まれます。 2.ファイアウォール設定を調整して、MySQLがポート3306をリッスンできるようにします。 3.ポート番号が実際のポート番号と一致していることを確認します。 4.ユーザー名とパスワードが正しいかどうかを確認します。 5. my.cnfのバインドアドレス設定が正しいことを確認してください。

MySQLワークベンチは、構成が正しい場合、MariadBに接続できます。最初にコネクタタイプとして「mariadb」を選択します。接続構成では、ホスト、ポート、ユーザー、パスワード、およびデータベースを正しく設定します。接続をテストするときは、ユーザー名とパスワードが正しいかどうか、ポート番号が正しいかどうか、ファイアウォールが接続を許可するかどうか、データベースが存在するかどうか、MariadBサービスが開始されていることを確認してください。高度な使用法では、接続プーリングテクノロジーを使用してパフォーマンスを最適化します。一般的なエラーには、不十分な権限、ネットワーク接続の問題などが含まれます。エラーをデバッグするときは、エラー情報を慎重に分析し、デバッグツールを使用します。ネットワーク構成を最適化すると、パフォーマンスが向上する可能性があります

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

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