当前位置: 首页 > 编程日记 > 正文

【Python之路】第二篇--初识Python

Python简介

Python可以应用于众多领域,如:数据分析、组件集成、网络服务、图像处理、数值计算和科学计算等众多领域。目前业内几乎所有大中型互联网企业都在使用Python,如:Youtube、Dropbox、BT、Quora(中国知乎)、豆瓣、知乎、Google、Yahoo!、Facebook、NASA、百度、腾讯、汽车之家、美团等。互联网公司广泛使用Python来做的事一般有:自动化运维自动化测试大数据分析、爬虫、Web 等。

Python的种类

    • Cpython
          Python的官方版本,使用C语言实现,使用最为广泛,CPython实现会将源文件(py文件)转换成字节码文件(pyc文件),然后运行在Python虚拟机上。
    • Jyhton
          Python的Java实现,Jython会将Python代码动态编译成Java字节码,然后在JVM上运行。
    • IronPython
          Python的C#实现,IronPython将Python代码编译成C#字节码,然后在CLR上运行。(与Jython类似)
    • PyPy(特殊)
          Python实现的Python,具有JIT(just In time)Compiler , 将Python的字节码字节码再编译成机器码。
    • RubyPython、Brython ...

为什么说pypy会比Cpython快?

代码有两种常见的执行方式,一种叫做编译执行,也就是直接将代码转换为CPU指令,然后连续执行这些指令,好处当然是非常快,一条多余的指令都没有;坏处则是难以支持许多动态特性。

一种叫做解释执行,也就是对每条语句在运行时用解释器去执行它相应的动作,好处是实现起来非常简单,也很容易添加新特性,坏处则是执行得非常慢,大部分CPU时间花在了解释器运行上面。

JIT技术是两者的结合,首先让代码解释执行,同时收集信息,在收集到足够信息的时候,将代码动态编译成CPU指令,然后用CPU指令替代解释执行的过程,因为编译发生在马上要执行之前,所以叫做Just-In-Time Compiler。编译之后速度就是编译执行的速度了,自然比解释执行要快得多,所以运用JIT的PyPy要比CPython快不少。

安装Python

windows:

1、下载安装包https://www.python.org/downloads/2、安装默认安装路径:C:\python273、配置环境变量【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》【在第二个内容框中找到 变量名为Path 的一行,双击】 --> 【Python安装目录追加到变值值中,用 ; 分割】如:原来的值 ;C:\python27 切记前面有分号!!    

Linux:

无需安装,原装Python环境
ps:如果自带2.6,请更新至2.7

更新Python:

  Windows:

卸载重装即可

Linux:

Linux的yum依赖自带Python,为防止错误,此处更新其实就是再安装一个Python查看默认Python版本
python -V1、安装gcc,用于编译Python源码yum install gcc
2、下载源码包,https://www.python.org/ftp/python/
3、解压并进入源码文件
4、编译安装./configuremake allmake install
5、查看版本/usr/local/bin/python2.7 -V
6、修改默认Python版本mv /usr/bin/python /usr/bin/python2.6ln -s /usr/local/bin/python2.7 /usr/bin/python
7、防止yum执行异常,修改yum使用的Python版本vi /usr/bin/yum将头部 #!/usr/bin/python 修改为 #!/usr/bin/python2.6

Python 入门

解释器

我们经常在py脚本的第一行 看到如下的代码:

#!/usr/bin/python  或者  #!/usr/bin/env python  那么它的作用是?

#!/usr/bin/Python 是告诉操作系统执行这个脚本的时候,调用/usr/bin下的python解释器;

#!/usr/bin/env python这种用法是为了防止操作系统用户没有将python装在默认的/usr/bin路径里。当系统看到这一行的时候,首先会到env设置里查找python的安装路径,再调用对应路径下的解释器程序完成操作。推荐这种写法

如此一来,我们就可以通过: ./hello.py 执行即可。

  ps:执行前需给予 hello.py 执行权限,chmod 755 hello.py

内容编码

python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill)

显然ASCII码无法将世界上的各种文字和符号全部表示,所以,就需要新出一种可以代表所有字符和符号的编码,即:Unicode

Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536,注:此处说的的是最少2个字节,可能更多

UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...

所以,python解释器在加载 .py 文件中的代码时,会对内容进行编码(默认ascill),如果是如下代码的话:

报错:ascii码无法表示中文

#!/usr/bin/env pythonprint "你好,世界"

改正:应该显示的告诉python解释器,用什么编码来执行源代码,即:

#!/usr/bin/env python
# -*- coding: utf-8 -*-print "你好,世界"

Python2 中字符串的类型:

Str:Bytes 类型

Unicode:unicode 类型

# coding:utf8

s = '你好'
print len(s)     # 6
print type(s)   #  <str>
print repr(s)   #  utf8格式 : '\xe4\xbd\xa0\xe5\xa5\xbd'# Unicode 形式:

s = u'你好'
print len(s)     # 2
print type(s)   #  <unicode>
print repr(s)   #  u'\u4f60\u597d'# bytes 与 Unicode 混用拼接
print 'hello'+u'world'      # 先把 bytes => unicode
print '你好'+u'世界'         # 报错, 只能将Ascii码转换,其余字符不行!

Python3 中字符串的类型:

Str:Unicode 类型

Bytes:Bytes 类型

# bytes 与 Unicode 混用拼接
print 'hello'+b'world'      # 报错,严格区分str和bytes

Python 编码形式:

Python 编码方式有两种:

s = 'hello'
b = b'hello'#  编码 encode  Str => Bytes
s.encode('utf8')
bytes(s,encoding='utf8')#  解码 decode  Bytes => Str  (需要知道原先的编码格式 utf8 or GBK ..)
b.decode('utf8')                 
str(s,encoding='utf8')

cmd 下的字符显示问题:

print('你好')# py2下为bytes 类型,根据cmd的编码形式去显示 修改为:print(u'你好')
# py3下为unicode 类型,正常显示,符合ISO统一标准的,

查看.py文件的编码格式:

import sys
print sys.getdefaultencoding()# py2: ascii
# py3: utf8

print问题:

在py2里

# coding:utf8
print('你好')           # 你好
print(['你好','hello']) # ['\xe4\xbd\xa0\xe5\xa5\xbd', 'hello']

在py3里

# coding:utf8
print('你好')            # 你好
print(['你好','hello'])  # ['你好', 'hello']

Python 中,print语句都会执行了:str()

# python2
sys.stdout.write(str(A) + '\n')

栗子:py3,将中文字符转换成二进制(bytes类型进行for循环print,会输出10进制数!)

name = "李路"len(name)
#长度等于2for i in name:print(i)bytes_list = bytes(i , encoding='utf-8')print(bytes_list )for b in bytes_list:print(b,bin(b))#李
#b'\xe6\x9d\x8e'
#230 0b11100110
#157 0b10011101
#142 0b10001110
#路
#b'\xe8\xb7\xaf'
#232 0b11101000
#183 0b10110111
#175 0b10101111

Str 与 Bytes

x = str()
# 功能:
# 1.创建字符串
# 2.转换成字符串	  编码类型x = bytes()
# 功能:
# 1.创建字节
# 2.转换成字节	编码类型
def __init__(self, value='', encoding=None, errors='strict'): # known special case of str.__init__"""str(object='') -> strstr(bytes_or_buffer[, encoding[, errors]]) -> strCreate a new string object from the given object. If encoding orerrors is specified, then the object must expose a data bufferthat will be decoded using the given encoding and error handler.Otherwise, returns the result of object.__str__() (if defined)or repr(object).encoding defaults to sys.getdefaultencoding().errors defaults to 'strict'.# (copied from class doc)"""pass
str
def __init__(self, value=b'', encoding=None, errors='strict'): # known special case of bytes.__init__"""bytes(iterable_of_ints) -> bytesbytes(string, encoding[, errors]) -> bytesbytes(bytes_or_buffer) -> immutable copy of bytes_or_bufferbytes(int) -> bytes object of size given by the parameter initialized with null bytesbytes() -> empty bytes objectConstruct an immutable array of bytes from:- an iterable yielding integers in range(256)- a text string encoded using the specified encoding- any object implementing the buffer API.- an integer# (copied from class doc)"""pass
bytes

三、注释

单行注释:# 被注释内容

多行注释:""" 被注释内容 """

四、执行脚本传入参数

Python内部提供一个 sys 的模块,其中的 sys.argv 用来捕获执行执行python脚本时传入的参数

#!/usr/bin/env python
# -*- coding: utf-8 -*-import sys
print sys.argv

比如用python test.py arg1 arg2运行test.py代码,那么argv列表的内容是[' test.py','arg1','arg2']

五、 pyc 文件

执行Python代码时,如果导入了其他的 .py 文件,那么,执行过程中会自动生成一个与其同名的 .pyc 文件,该文件就是Python解释器编译之后产生的字节码。

ps:代码经过编译可以产生字节码;字节码通过反编译也可以得到代码。执行时优先搜索字节码文件

六、变量

变量定义的规则:

  • 变量名只能是 字母、数字或下划线的任意组合
  • 变量名的第一个字符不能是数字
  • 以下关键字不能声明为变量名
  • ['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']

七、输入

#!/usr/bin/env python
# -*- coding: utf-8 -*-# 将用户输入的内容赋值给 name 变量
name = raw_input("请输入用户名:")#python3
name = input("请输入用户名:")# 打印输入的内容
print(name)

输入密码时,如果想要不可见,需要利用getpass 模块中的 getpass方法,即:

#!/usr/bin/env python
# -*- coding: utf-8 -*-import getpass# 将用户输入的内容赋值给 name 变量
pwd = getpass.getpass("请输入密码:")# 打印输入的内容
print pwd

八、流程控制和缩进

需求一、用户登陆验证

#!/usr/bin/env python
# -*- coding: encoding -*-# 提示输入用户名和密码# 验证用户名和密码
#     如果错误,则输出用户名或密码错误
#     如果成功,则输出 欢迎,XXX!import getpassname = raw_input('请输入用户名:')
pwd = getpass.getpass('请输入密码:')if name == "alex" and pwd == "cmd":print "欢迎,alex!"
else:print "用户名和密码错误"

需求二、根据用户输入内容输出其权限

# 根据用户输入内容打印其权限# alex --> 超级管理员
# eric --> 普通管理员
# tony,rain --> 业务主管
# 其他 --> 普通用户name = raw_input('请输入用户名:')if name == "alex":print "超级管理员"
elif name == "eric":print "普通管理员"
elif name == "tony" or name == "rain":print "业务主管"
else:print "普通用户"

九、while循环

1、基本循环

while 条件:# 循环体# 如果条件为真,那么循环体则执行# 如果条件为假,那么循环体不执行

2、break

break用于退出所有循环

while True:print "123"breakprint "456"

3、continue

continue用于退出当前循环,继续下一次循环

while True:print "123"continueprint "456"

十、练习题

1、使用while循环输入 1 2 3 4 5 6     8 9 10

1 #!/usr/bin/env python
2 # -*-coding:utf-8 -*-
3 num = 0
4 while num <10:
5     num += 1
6     if num == 7:
7         continue
8     print(num)
View Code

2、求1-100的所有数的和

1 #!/usr/bin/env python
2 # -*-coding:utf-8 -*-
3 num = 1
4 sum = 0
5 while num<=100:
6     sum = sum + num
7     num +=1
8 
9 print(sum)
View Code

3、输出 1-100 内的所有奇数

 1 #!/usr/bin/env python
 2 # -*-coding:utf-8 -*-
 3 
 4 num = 1
 5 
 6 while 1:
 7     if  num % 2 == 1:
 8         print(num)
 9     num += 1
10     if num == 100:
11         break
View Code

4、输出 1-100 内的所有偶数

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3  
 4 num = 1
 5  
 6 while 1:
 7     if num % 2 ==0:
 8         print(num)
 9     if num == 100:
10         break
11     num += 1
View Code

5、求1-2+3-4+5 ... 99的所有数的和

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3  
 4 num = 1
 5 sum =0
 6  
 7 while 1:
 8     if num == 100:
 9         break
10     if num % 2 == 1:
11         sum = sum + num
12     else:
13         sum = sum - num
14     num +=1
15  
16 print(sum)
View Code

6、用户登陆(三次机会重试)

 1 #!/usr/bin/env python
 2 # -*- coding:utf-8 -*-
 3  
 4 count = 0
 5  
 6 while 1:
 7     if count == 3:
 8         break
 9     username = input("username :")
10     password = input("password :")
11  
12     if username == 'admin' and password == 'admin123':
13         print(" Welcome !")
14         break
15     else:
16         count +=1
17         continue
View Code

转载于:https://www.cnblogs.com/5poi/p/6046495.html

相关文章:

如何实现phpcms v9_4X版本tag的伪静态?

这两个月来写的文章越来越少了&#xff0c;不是懒&#xff0c;因为太忙了--为客户赶做网站。因为客户指定要使用phpcms v9,还要求使用phpcms v9_42版本实现tag伪静态&#xff0c;在接手的时候phpcms v9_42是最新版本&#xff0c;而现在phpcms官方已经发布phpcms v9_5.X了。对于…

OC对象内存布局

OC对象的内存布局 1 每一个实例对象&#xff08;Instance&#xff09;内部都有一个isa指针&#xff0c;指向它的类对象&#xff0c;类对象存放着本对象的实例方法列表和成员变量列表。 2 类对象(Class)内部也有一个isa指针指向元类对象(MetaClass)&#xff0c;元类对象存放的事…

连信的protobuf数据格式

点击上方↑↑↑蓝字[协议分析与还原]关注我们“ 连信里用到的protobuf结构。”在看本文之前&#xff0c;可以先进行一下回顾&#xff0c;之前已经对协议的框架进行了整体的介绍&#xff1a;连信协议整体框架看了后结合自己的分析过程&#xff0c;应该有个初步的了解。后续会陆续…

fileupload控件在ajax中无法使用

google得到的方法&#xff1a;1。http://geekswithblogs.net/ranganh/archive/2008/04/01/file-upload-in-updatepanel-asp.net-ajax.aspxThere is a better way of doing it with Ajax Control Toolkit version 3.0.30930 which works with .NET 3.5 SP1 and Visual Studio 20…

Cron表达式的详细用法

字段 允许值 允许的特殊字符 秒 0-59 , - * / 分 0-59 , - * / 小时 0-23 , - * / 日期 1-31 , - * ? / L W C 月份 1-12 或者 JAN-DEC , - * / 星期 1-7 或者 SUN-SAT , - * ? / L C # 年&#xff08;可选&#xff09; 留空, 1970-2099 , - * / 例子&#xff1a;0/5 * * * *…

01-CoreData 概述

CoreData 主要的几个类 1 概述 CoreData 是iOS 3 之后出现的一种数据持久化方案&#xff0c;提供了一种ORM的存储关系&#xff0c;CoreData 是直接将对象存储到数据库中去&#xff0c;也可以将数据库中的数据转化为OC对象&#xff0c;过程中不用编写SQL语句。 2 几个类的讲解…

连信的会话加密密钥协商过程

点击上方↑↑↑蓝字[协议分析与还原]关注我们 “ 介绍连信会话加密密钥的协商过程。” 公号内之前已经对协议的框架和协议内的数据格式进行了介绍&#xff0c;有需要可以回顾下&#xff1a; 连信协议整体框架 连信的protobuf数据格式 本文对连信的会话加密密钥协商过程进行介绍…

6、UmbracoNewsSite:添加新闻分类

上一篇做了一个简单的首页&#xff0c;在导航条上添加了几个新闻板块&#xff0c;接下来我们就添加这几个新闻板块的页面。 开始我们还是需要创建Document Types用来展示新闻列表。我们先做好规划&#xff0c;新闻列表只需要把新闻标题和图片展示出来就可以了&#xff0c;。  …

02-CoreData 的增删改查

CoreData 的增删改查 基本的增删改查的操作 1 数据库的创建 - (void)createDB {// 1.1 创建路径NSURL *modelURL [[NSBundle mainBundle] URLForResource:"AT_CoreDataDemo1" withExtension:"momd"];// 1.2 根据模型文件路径创建模型对象NSManagedObje…

Lemon开源OA

http://www.mossle.com/index.html 转载于:https://www.cnblogs.com/gzmg/p/3770882.html

UC浏览器代理流量解密

点击上方↑↑↑蓝字[协议分析与还原]关注我们“ 解密uc浏览器的安全代理流量&#xff0c;看看是不是真安全。”作为一个从上古网络时代过来的人&#xff0c;一定对UC浏览器有深刻印象&#xff0c;它的流量透明代理功能&#xff0c;就是现在的云加速功能&#xff0c;使用UC的服务…

JAVA07 接口与继承

一 动手实验&#xff1a;继承条件下的构造方法调用 1&#xff09;源代码 1 public class TestInherits {2 3 public static void main(String[] args) {4 // TODO Auto-generated method stub5 6 Child c new Child();7 }8 9 } 10 11 class GrandPa…

学习-现代交换原理与通信技术

帮助学习细化。。。 首先&#xff0c;这书真是难读&#xff0c;像个词典嘛似乎《现代交换原理与通信技术》卞佳丽 北邮 呵呵 呵了个呵 不过词典也有词典的好处 第三章&#xff0c;数字程控电话交换与通信网络 1. 控制子系统 与 话路子系统 前者在于控制&#xff0c;后者在于数…

03-NSPredicate谓词

NSPredicate 谓词 在查询数据的过程中&#xff0c;给NSFetchRequest设置一个过滤条件&#xff0c;不需要讲所有的托管对象加载到内存中去。这样的话就会节省内存和加快查找速度。 一 运算符 1 比较运算符 、< 、 、> 、< 、! 比如说age>80 NSPredicate *pre […

小兵别嚣张,签名算法分析

点击上方↑↑↑蓝字[协议分析与还原]关注我们“分析unity3d游戏小兵别嚣张的签名算法。”不久前&#xff0c;写了个unity3d的引子&#xff0c;介绍了使用工具从unity3d游戏中提取出各种资源和算法&#xff1a;unity3d游戏IL2CPP相关算法简单分析不过内容很少&#xff0c;今天介…

NOIP模拟题——B

【题目描述】我们要从n种食物选m个出来&#xff0c;安排一个顺序吃掉它&#xff08;们&#xff09;&#xff0c;每种食物有个美味值ai&#xff0c;然后我们有k个规则&#xff0c;每个规则有 xi, yi 和 ci三个数&#xff0c;如果吃完第xi种食物接下来马上吃第yi种食物&#xff0…

Maven使用常用命令

> mvn clean删除target文件夹> mvn clean test编译测试代码&#xff0c;默认被放到target/test-classes文件夹下面> mvn clean compile编译主代码&#xff0c;并放到target/classes文件夹下> mvn clean package打包代码&#xff0c;我们可以看到target文件下生成了…

04- CoreData轻量级版本的迁移

CoreData版本的迁移 一 轻量级的数据迁移 例如添加新的实体&#xff0c;新的实体属性。 轻量级版本迁移方案非常简单&#xff0c;大多数迁移工作都是由系统完成的&#xff0c;只需要告诉系统迁移方式即可。在持久化存储协调器(PSC)初始化对应的持久化存储(NSPersistentStore…

通da信TCP长连接数据算法分析

点击上方↑↑↑蓝字[协议分析与还原]关注我们“ 分析通da信TCP长连接内部分数据的算法。”作为一款老牌的炒股软件&#xff0c;通da信里面的数据是相当的丰富&#xff0c;免费的也很丰富&#xff0c;准确性也很好&#xff0c;例如&#xff0c;这种股票之间关联的信息。通da信一…

产品经理怎么样用图表传达数据信息(多图)

上文有点仓促了&#xff0c;结尾没有写好。补上&#xff1a; 对劣质成本分析的时候应该注意&#xff1a; 1、在进行劣质成本分析的时候&#xff0c;要注意区分成本和必要的浪费。要注意一个关系&#xff0c;对必要浪费的控制会导致其他成本的上升。例如前文说到四小时送一次货&…

'This NSPersistentStoreCoordinator has no persistent stores 报错

可能是你改变coredata的属性项之后再运行的话在模拟器中会出现这个问题。找上面说的&#xff0c;找到mac下的模拟器中的程序路径&#xff0c;然后删掉其sqlite文件再运行就好了&#xff01;&#xff01;&#xff01;

tcp断开连接,4次握手,为什么wireshark 只能抓到3个包?

用wireshark 抓包&#xff0c;看看tcp 断开连接的过程. 以前书上说tcp断开连接&#xff0c;4次握手&#xff0c;可我为什么wireshark 只能抓到3个包&#xff1f; 百度一下&#xff0c;别人也有类似的疑问。 【求助】书上和网上的资料说&#xff0c;TCP拆除连接需要四次握手。但…

如何在python开发的GUI界面程序中恰当地使用PyExecJS

点击上方↑↑↑蓝字[协议分析与还原]关注我们“解决一闪而过的黑框的小技巧。”在使用python开发过程中&#xff0c;不可避免地&#xff0c;会开发带界面的应用&#xff0c;也会经常使用js来完成一些功能&#xff0c;比如&#xff0c;我使用python开发个了一个小应用&#xff1…

switch和case的理解

下面是复习java基础知识的时候&#xff0c;发现的一些点&#xff0c;总结下&#xff0c;备忘 int a345;switch (a) {case 23:System.out.println("23"); // break;case 345://条件符合&#xff0c;下面的case条件不会在判断&#xff0c;直接执行&#xff1b;System…

05-自己创建mapmodel自定义迁移方式

自动创建Mapping 如果模型的改变很大或者不支持轻量级数据迁移的条件&#xff0c;则我们需要进行自定义迁移。 使用映射模型 适用于更加复杂的数据的迁移 NSMappingModel 类似于数据模型 NSEntityMapping 告知迁移过程如何在目标数据存储中处理源实体的映射。 映射类型决…

Linux内核之内存管理(4)--缺页处理程序

本文主要解说缺页处理程序&#xff0c;凝视足够具体&#xff0c;不再解释。 //以下函数将一页内存页面映射到指定线性地址处&#xff0c;它返回页面的物理地址 //把一物理内存页面映射到线性地址空间指定处或者说把线性地址空间指定地址address处的页面映射到主内存区页面page上…

WebSocket协议分析

点击上方↑↑↑蓝字[协议分析与还原]关注我们“ 解析websocket数据格式。”好久不见&#xff0c;一晃一年又过去了&#xff0c;祝大家新年好运。今天&#xff0c;给大家分析一个常见的协议——WebSocket&#xff0c;这是一个标准协议&#xff0c;虽然没有HTTP历史悠久&#xff…

《postfix邮件服务下mailq、postmap、postqueue 、 postsuper等用法》

1、Mailq 功能说明&#xff1a;显示待寄邮件的清单。 语  法&#xff1a;mailq [-q] 补充说明&#xff1a;mailq可列出待寄邮件的清单&#xff0c;包括邮件ID&#xff0c;邮件大小&#xff0c;邮件保存时间&#xff0c;寄信人&#xff0c;收信人&#xff0c;以及邮件无法寄出…

[deviceone开发]-一个很炫的手势动画示例

一、简介 这是iOS下的效果&#xff0c;android下完全一致。通过do_GestureView组件和do_Animation组件&#xff0c;deviceone能很容易实现复杂的跨平台纯原生动画效果,这个示例就是通过手势控制图片上下动画滑动实现开合效果&#xff0c;还支持声音效果。 二、效果图 三、相关下…

iOS lldb调试

LLDB 初始 LLDB 是一个有着 REPL 的特性和 C ,Python 插件的开源调试器。LLDB 绑定在 Xcode 内部&#xff0c;存在于主窗口底部的控制台中。调试器允许你在程序运行的特定时暂停它&#xff0c;你可以查看变量的值&#xff0c;执行自定的指令&#xff0c;并且按照你所认为合适的…