目次
基本データ型
数値型
コンテナ タイプ
String
自定义类型
ホームページ バックエンド開発 Python チュートリアル Python での 4 つの主要なデータ型の例を分析する

Python での 4 つの主要なデータ型の例を分析する

May 09, 2023 pm 09:16 PM
python

基本データ型

数値型

Python のデータは、よく知られている int 整数オブジェクト、float 倍精度浮動小数点型、bool 論理オブジェクトなど、すべてのオブジェクトです。すべては単一の要素です。例を 2 つ挙げてください。

プレフィックス 0x を付けて 16 進整数を作成します:

0xa5 # 等于十进制的 165
ログイン後にコピー

e を使用して科学表記法で表される浮動小数点数を作成します:

1.05e3 # 1050.0
ログイン後にコピー

コンテナ タイプ

複数の要素を収容できるコンテナ オブジェクト。一般的に使用されるものには、リスト リスト オブジェクト、タプル タプル オブジェクト、辞書辞書オブジェクト、セット コレクション オブジェクトなどがあります。 Python は、これらのタイプの変数を非常に簡潔な構文で定義します。

例は次のとおりです。

角かっこ [] のペアを使用してリスト変数を作成します:

lst = [1,3,5] # list 变量
ログイン後にコピー

図からわかるように、右側のコンテナは開ループです。これは、コンテナが次の要素の追加と削除を行うことができることを意味します:

Python での 4 つの主要なデータ型の例を分析する

一対のかっこ () を使用してタプル オブジェクトを作成します:

tup = (1,3,5) # tuple 变量
ログイン後にコピー

図に示すように、右側のコンテナは閉じられています。つまり、タプルが作成されると、要素をコンテナに追加したりコンテナから削除したりすることはできません。

Python での 4 つの主要なデータ型の例を分析する

ただし、単一の要素を含むタプルをタプルとして解釈するには、カンマを残す必要があることに注意してください。

tup = (1,) # 必须保留逗号
ログイン後にコピー

それ以外の場合は要素自体とみなされます:

In [14]: tup=(1)
   ...: print(type(tup)) 
<class &#39;int&#39;>
ログイン後にコピー

一対の中括弧 {} を使用し、コロン : を使用して作成しますdict オブジェクト:

dic = {&#39;a&#39;:1, &#39;b&#39;:3, &#39;c&#39;:5} # dict变量
ログイン後にコピー

辞書はハッシュ テーブルです。次の図は辞書の「形」を鮮やかに表しています。

Python での 4 つの主要なデータ型の例を分析する

中括弧のペア {} のみを使用してセット オブジェクトを作成します:

s = {1,3,5} # 集合变量
ログイン後にコピー

Python コンテナ タイプ、リスト、辞書、tuple、set などを使用すると、強力な関数を簡単に実装できます。

1. 平均を求める

リスト内の最小値と最大値を削除した後、残りの要素の平均を計算します。

def score_mean(lst):
   lst.sort()
   lst2=lst[1:-1]
   return round((sum(lst2)/len(lst2)),1)

lst=[9.1, 9.0,8.1, 9.7, 19,8.2, 8.6,9.8]
score_mean(lst) # 9.1
ログイン後にコピー

コード実行プロセス、アニメーションのデモ:

Python での 4 つの主要なデータ型の例を分析する

2. 99 の九九を印刷します

次の形式の乗算表:

1*1=1
1*2=2   2*2=4
1*3=3   2*3=6   3*3=9
1*4=4   2*4=8   3*4=12  4*4=16
1*5=5   2*5=10  3*5=15  4*5=20  5*5=25
1*6=6   2*6=12  3*6=18  4*6=24  5*6=30  6*6=36
1*7=7   2*7=14  3*7=21  4*7=28  5*7=35  6*7=42  7*7=49
1*8=8   2*8=16  3*8=24  4*8=32  5*8=40  6*8=48  7*8=56  8*8=64
1*9=9   2*9=18  3*9=27  4*9=36  5*9=45  6*9=54  7*9=63  8*9=72  9*9=81
ログイン後にコピー

には合計 10 行があります。i 番目の行の j 番目の列は、次と同じです: j*i、ここで:

  • i 値の範囲: 1<=i<=9

  • j 値の範囲: 1<=j&lt ;=i

「分析例」の言語説明によると、

In [13]: for i in range(1,10):
   ...:     for j in range(1,i+1):
   ...:         print(&#39;%d*%d=%d&#39;%(j,i,j*i),end=&#39;\t&#39;)
   ...:     print()
ログイン後にコピー

3 というコードに変換されます。サンプリング

サンプル サンプリング を使用します。次の例では、100 個のサンプルからランダムに 10 個のサンプルをサンプリングします。

from random import randint,sample
lst = [randint(0,50) for _ in range(100)]
print(lst[:5])# [38, 19, 11, 3, 6]
lst_sample = sample(lst,10)
print(lst_sample) # [33, 40, 35, 49, 24, 15, 48, 29, 37, 24]
ログイン後にコピー

String

Python には C のような文字型 (char) がなく、すべての文字または文字列は str オブジェクトに統一されることに注意してください。たとえば、単一文字 c の型も str です。

よく使われるstr型ですが、まずはよく使うメソッドを5つ挙げてみましょう。

strip は文字列の前後のスペースを削除するために使用されます:

In [1]: &#39;  I love python\t\n  &#39;.strip()
Out[1]: &#39;I love python&#39;
ログイン後にコピー

replace は文字列を置換するために使用されます:

In [2]: &#39;i love python&#39;.replace(&#39; &#39;,&#39;_&#39;)
Out[2]: &#39;i_love_python&#39;
ログイン後にコピー

join は文字列をマージするために使用されます:

In [3]: &#39;_&#39;.join([&#39;book&#39;, &#39;store&#39;,&#39;count&#39;])
Out[3]: &#39;book_store_count&#39;
ログイン後にコピー

title は、単語の最初の文字を大文字にするために使用されます。

In [4]: &#39;i love python&#39;.title()
Out[4]: &#39;I Love Python&#39;
ログイン後にコピー

find は、一致する文字列の開始位置インデックスを返すために使用されます。

In [5]: &#39;i love python&#39;.find(&#39;python&#39;)
Out[5]: 7
ログイン後にコピー

文字列を適用する例として、 str1 が回転された str2 で構成されているかどうかを判断します。

文字列 stringbook を回転して bookstring を取得します。str1 が回転して得られた str2 であるかどうかを確認するコードを記述します。

判定に変換: str1 が str2 str2 の部分文字列であるかどうか。

下面函数原型中,注明了每个参数的类型、返回值的类型,增强代码的可读性和可维护性。

def is_rotation(s1: str, s2: str) -> bool:
   if s1 is None or s2 is None:
       return False
   if len(s1) != len(s2):
       return False

   def is_substring(s1: str, s2: str) -> bool:
       return s1 in s2
   return is_substring(s1, s2 + s2)
ログイン後にコピー

测试函数 is_rotation:

r = is_rotation(&#39;stringbook&#39;, &#39;bookstring&#39;)
print(r)  # True

r = is_rotation(&#39;greatman&#39;, &#39;maneatgr&#39;)
print(r)  # False
ログイン後にコピー

代码执行过程,动画演示:

55555

字符串的匹配操作除了使用 str 封装的方法外,Python 的 re 正则模块功能更加强大,写法更为简便,广泛适用于爬虫、数据分析等。

下面这个案例实现:密码安全检查,使用正则表达式非常容易实现。

密码安全要求:

  • 要求密码为 6 到 20 位;

  • 密码只包含英文字母和数字。

import re
pat = re.compile(r&#39;\w{6,20}&#39;) # 这是错误的,因为 \w 通配符匹配的是字母,数字和下划线,题目要求不能含有下划线
# 使用最稳的方法:\da-zA-Z 满足“密码只包含英文字母和数字”
# \d匹配数字 0-9
# a-z 匹配所有小写字符;A-Z 匹配所有大写字符
pat = re.compile(r&#39;[\da-zA-Z]{6,20}&#39;)
ログイン後にコピー

选用最保险的 fullmatch 方法,查看是否整个字符串都匹配。

以下测试例子都返回 None,原因都在解释里。

pat.fullmatch(&#39;qaz12&#39;) # 返回 None,长度小于 6
pat.fullmatch(&#39;qaz12wsxedcrfvtgb67890942234343434&#39;) # None 长度大于 22
pat.fullmatch(&#39;qaz_231&#39;) # None 含有下划线
ログイン後にコピー

下面这个字符串 n0passw0Rd 完全符合:

In [20]: pat.fullmatch(&#39;n0passw0Rd&#39;)
Out[20]: <re.Match object; span=(0, 10), match=&#39;n0passw0Rd&#39;>
ログイン後にコピー

自定义类型

Python 使用关键字 class 定制自己的类,self 表示类实例对象本身。

一个自定义类内包括属性、方法,其中有些方法是自带的。

类(对象):

class Dog(object):
   pass
ログイン後にコピー

以上定义一个 Dog 对象,它继承于根类 object,pass 表示没有自定义任何属性和方法。

下面创建一个 Dog 类型的实例:

wangwang = Dog()
ログイン後にコピー

Dog 类现在没有定义任何方法,但是刚才说了,它会有自带的方法,使用 dir() 查看这些自带方法:

In [26]: wangwang.__dir__()
Out[26]:
[&#39;__module__&#39;,
&#39;__dict__&#39;,
&#39;__weakref__&#39;,
&#39;__doc__&#39;,
&#39;__repr__&#39;,
&#39;__hash__&#39;,
&#39;__str__&#39;,
&#39;__getattribute__&#39;,
&#39;__setattr__&#39;,
&#39;__delattr__&#39;,
&#39;__lt__&#39;,
&#39;__le__&#39;,
&#39;__eq__&#39;,
&#39;__ne__&#39;,
&#39;__gt__&#39;,
&#39;__ge__&#39;,
&#39;__init__&#39;,
&#39;__new__&#39;,
&#39;__reduce_ex__&#39;,
&#39;__reduce__&#39;,
&#39;__subclasshook__&#39;,
&#39;__init_subclass__&#39;,
&#39;__format__&#39;,
&#39;__sizeof__&#39;,
&#39;__dir__&#39;,
&#39;__class__&#39;]
ログイン後にコピー

有些地方称以上方法为魔法方法,它们与创建类时自定义个性化行为有关。比如:

  • init 方法能定义一个带参数的类;

  • new 方法自定义实例化类的行为;

  • getattribute 方法自定义读取属性的行为;

  • setattr 自定义赋值与修改属性时的行为。

类的属性:

def __init__(self, name, dtype):
    self.name = name
    self.dtype = dtype
ログイン後にコピー

通过 init,定义 Dog 对象的两个属性:name、dtype。

类的实例:

wangwang = Dog(&#39;wangwang&#39;,&#39;cute_type&#39;)
ログイン後にコピー

wangwangDog 类的实例。

类的方法:

def shout(self):
   print(&#39;I\&#39;m %s, type: %s&#39; % (self.name, self.dtype))
ログイン後にコピー

注意:

  • 自定义方法的第一个参数必须是 self,它指向实例本身,如 Dog 类型的实例 dog;

  • 引用属性时,必须前面添加 self,比如 self.name 等。

总结以上代码:

In [40]: class Dog(object):
   ...:     def __init__(self,name,dtype):
   ...:         self.name=name
   ...:         self.dtype=dtype
   ...:     def shout(self):
   ...:         print('I\'m %s, type: %s' % (self.name, self.dtype))

In [41]: wangwang = Dog(&#39;wangwang&#39;,&#39;cute_type&#39;)

In [42]: wangwang.name
Out[42]: 'wangwang'

In [43]: wangwang.dtype
Out[43]: 'cute_type'

In [44]: wangwang.shout()
I'm wangwang, type: cute_type
ログイン後にコピー

看到创建的两个属性和一个方法都被暴露在外面,可被 wangwang 调用。这样的话,这些属性就会被任意修改:

In [49]: wangwang.name=&#39;wrong_name&#39;
   
In [50]: wangwang.name
Out[50]: &#39;wrong_name&#39;
ログイン後にコピー

如果想避免属性 name 被修改,可以将它变为私有变量。改动方法:属性前加 2 个 _ 后,变为私有属性。如:

In [51]: class Dog(object):
   ...:     def __init__(self,name,dtype):
   ...:         self.__name=name
   ...:         self.__dtype=dtype
   ...:     def shout(self):
   ...:         print(&#39;I\&#39;m %s, type: %s&#39; % (self.name, self.dtype))
ログイン後にコピー

同理,方法前加 2 个 _ 后,方法变为“私有方法”,只能在 Dog 类内被共享使用。

但是这样改动后,属性 name 不能被访问了,也就无法得知 wangwang 的名字叫啥。不过,这个问题有一种简单的解决方法,直接新定义一个方法就行:

def get_name(self):
   return self.__name
ログイン後にコピー

综合代码:

In [52]: class Dog(object):
   ...:     def __init__(self,name,dtype):
   ...:         self.__name=name
   ...:         self.__dtype=dtype
   ...:     def shout(self):
   ...:         print('I\'m %s, type: %s' % (self.name, self.dtype))
   ...:     def get_name(self):
   ...:         return self.__name
   ...:

In [53]: wangwang = Dog(&#39;wangwang&#39;,&#39;cute_type&#39;)

In [54]: wangwang.get_name()
Out[54]: 'wangwang'
ログイン後にコピー

但是,通过此机制,改变属性的可读性或可写性,怎么看都不太优雅!因为无形中增加一些冗余的方法,如 get_name。

下面,通过另一个例子,解释如何更优雅地改变某个属性为只读或只写。

自定义一个最精简的 Book 类,它继承于系统的根类 object:

class Book(object):
   def __init__(self,name,sale):
       self.__name = name
       self.__sale = sale
ログイン後にコピー

使用 Python 自带的 property 类,就会优雅地将 name 变为只读的。

   @property
   def name(self):
       return self.__name
ログイン後にコピー

使用 @property 装饰后 name 变为属性,意味着 .name 就会返回这本书的名字,而不是通过 .name() 这种函数调用的方法。这样变为真正的属性后,可读性更好。

In [101]: class Book(object):
    ...:     def __init__(self,name,sale):
    ...:         self.__name = name
    ...:         self.__sale = sale
    ...:     @property
    ...:     def name(self):
    ...:         return self.__name

In [102]: a_book = Book(&#39;magic_book&#39;,100000)

In [103]: a_book.name
Out[103]: &#39;magic_book&#39;
ログイン後にコピー

property 是 Python 自带的类,前三个参数都是函数类型。更加详细的讨论放在后面讨论装饰器时再展开。

In [104]: help(property)
Help on class property in module builtins:

class property(object)
|  property(fget=None, fset=None, fdel=None, doc=None)
ログイン後にコピー

如果使 name 既可读又可写,就再增加一个装饰器 @name.setter。

In [105]: class Book(object):
    ...:     def __init__(self,name,sale):
    ...:         self.__name = name
    ...:         self.__sale = sale
    ...:     @property
    ...:     def name(self):
    ...:         return self.__name
    ...:     @name.setter
    ...:     def name(self,new_name):
    ...:         self.__name = new_name

In [106]: a_book = Book(&#39;magic_book&#39;,100000)

In [107]: a_book.name = &#39;magic_book_2.0&#39;

In [108]: a_book.name
Out[108]: &#39;magic_book_2.0&#39;
ログイン後にコピー

注意这种装饰器写法:name.setter,name 已经被包装为 property 实例,调用实例上的 setter 函数再包装 name 后就会可写。对于 Python 入门者,可以暂时不用太纠结这部分理论,使用 Python 一段时间后,再回过头来自然就会理解。

以上がPython での 4 つの主要なデータ型の例を分析するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

PHPおよびPython:コードの例と比較 PHPおよびPython:コードの例と比較 Apr 15, 2025 am 12:07 AM

PHPとPythonには独自の利点と短所があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1.PHPは、大規模なWebアプリケーションの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンスと機械学習の分野を支配しています。

CentosでPytorchモデルを訓練する方法 CentosでPytorchモデルを訓練する方法 Apr 14, 2025 pm 03:03 PM

CentOSシステムでのPytorchモデルの効率的なトレーニングには手順が必要であり、この記事では詳細なガイドが提供されます。 1。環境の準備:Pythonおよび依存関係のインストール:Centosシステムは通常Pythonをプリインストールしますが、バージョンは古い場合があります。 YumまたはDNFを使用してPython 3をインストールし、PIP:sudoyumupdatepython3(またはsudodnfupdatepython3)、pip3install-upgradepipをアップグレードすることをお勧めします。 cuda and cudnn(GPU加速):nvidiagpuを使用する場合は、cudatoolをインストールする必要があります

CentosのPytorchのGPUサポートはどのようにサポートされていますか CentosのPytorchのGPUサポートはどのようにサポートされていますか Apr 14, 2025 pm 06:48 PM

Pytorch GPUアクセラレーションを有効にすることで、CentOSシステムでは、PytorchのCUDA、CUDNN、およびGPUバージョンのインストールが必要です。次の手順では、プロセスをガイドします。CUDAおよびCUDNNのインストールでは、CUDAバージョンの互換性が決定されます。NVIDIA-SMIコマンドを使用して、NVIDIAグラフィックスカードでサポートされているCUDAバージョンを表示します。たとえば、MX450グラフィックカードはCUDA11.1以上をサポートする場合があります。 cudatoolkitのダウンロードとインストール:nvidiacudatoolkitの公式Webサイトにアクセスし、グラフィックカードでサポートされている最高のCUDAバージョンに従って、対応するバージョンをダウンロードしてインストールします。 cudnnライブラリをインストールする:

Dockerの原則の詳細な説明 Dockerの原則の詳細な説明 Apr 14, 2025 pm 11:57 PM

DockerはLinuxカーネル機能を使用して、効率的で孤立したアプリケーションランニング環境を提供します。その作業原則は次のとおりです。1。ミラーは、アプリケーションを実行するために必要なすべてを含む読み取り専用テンプレートとして使用されます。 2。ユニオンファイルシステム(UnionFS)は、違いを保存するだけで、スペースを節約し、高速化する複数のファイルシステムをスタックします。 3.デーモンはミラーとコンテナを管理し、クライアントはそれらをインタラクションに使用します。 4。名前空間とcgroupsは、コンテナの分離とリソースの制限を実装します。 5.複数のネットワークモードは、コンテナの相互接続をサポートします。これらのコア概念を理解することによってのみ、Dockerをよりよく利用できます。

Python vs. JavaScript:コミュニティ、ライブラリ、リソース Python vs. JavaScript:コミュニティ、ライブラリ、リソース Apr 15, 2025 am 12:16 AM

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

Centosの下でPytorchバージョンを選択する方法 Centosの下でPytorchバージョンを選択する方法 Apr 14, 2025 pm 02:51 PM

CentOSでPytorchバージョンを選択する場合、次の重要な要素を考慮する必要があります。1。CUDAバージョンの互換性GPUサポート:NVIDIA GPUを使用してGPU加速度を活用したい場合は、対応するCUDAバージョンをサポートするPytorchを選択する必要があります。 NVIDIA-SMIコマンドを実行することでサポートされているCUDAバージョンを表示できます。 CPUバージョン:GPUをお持ちでない場合、またはGPUを使用したくない場合は、PytorchのCPUバージョンを選択できます。 2。PythonバージョンPytorch

CentosでPytorchの分散トレーニングを操作する方法 CentosでPytorchの分散トレーニングを操作する方法 Apr 14, 2025 pm 06:36 PM

Pytorchの分散トレーニングでは、Centosシステムでトレーニングには次の手順が必要です。Pytorchのインストール:PythonとPipがCentosシステムにインストールされていることです。 CUDAバージョンに応じて、Pytorchの公式Webサイトから適切なインストールコマンドを入手してください。 CPUのみのトレーニングには、次のコマンドを使用できます。PipinstalltorchtorchtorchvisionTorchaudioGPUサポートが必要な場合は、CUDAとCUDNNの対応するバージョンがインストールされ、インストールに対応するPytorchバージョンを使用してください。分散環境構成:分散トレーニングには、通常、複数のマシンまたは単一マシンの複数GPUが必要です。場所

NginxをCentosにインストールする方法 NginxをCentosにインストールする方法 Apr 14, 2025 pm 08:06 PM

NGINXのインストールをインストールするには、次の手順に従う必要があります。開発ツール、PCRE-Devel、OpenSSL-Develなどの依存関係のインストール。 nginxソースコードパッケージをダウンロードし、それを解凍してコンパイルしてインストールし、/usr/local/nginxとしてインストールパスを指定します。 nginxユーザーとユーザーグループを作成し、アクセス許可を設定します。構成ファイルnginx.confを変更し、リスニングポートとドメイン名/IPアドレスを構成します。 nginxサービスを開始します。依存関係の問題、ポート競合、構成ファイルエラーなど、一般的なエラーに注意する必要があります。パフォーマンスの最適化は、キャッシュをオンにしたり、ワーカープロセスの数を調整するなど、特定の状況に応じて調整する必要があります。

See all articles