微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Python基础语法(Python基础知识点)

Python与Perl,C和Java语言等有许多相似之处。不过,也有语言之间有一些明确的区别。本章的目的是让你迅速学习Python的语法。

一个Python程序:

交互模式编程:

调用解释器不经过脚本文件作为参数,显示以下提示

$ python
Python 2.6.4 (#1,Nov 11 2014,13:34:43)
[GCC 4.1.2 20120704 (Red Hat 5.6.2-48)] on linux2
Type "help","copyright","credits" or "license" for more information.
>>>

键入下列文字在Python提示符,然后按Enter键:

>>> print "Hello,Python!";

如果您运行的是新的Python版本,那么需要使用打印语句括号像print ("Hello,Python!");。但是在Python版本2.6.4,这将产生以下结果:

Hello,Python!

脚本模式编程:

调用解释器及脚本作为参数,并开始执行的脚本,并一直持续到脚本完成。当脚本完成时,解释器不再是活动的。

让我们在脚本中编写一个简单的Python程序。所有的Python文件将具有.py扩展。所以,把下面的代码写在一个test.py文件

print "Hello,Python!";

在这里,我假设你已经在PATH变量中设置Python解释器。现在,尝试如下运行这个程序:

$ python test.py

这将产生以下结果:

Hello,Python!

让我们尝试另一种方式来执行Python脚本。下面是修改后的test.py文件


#!/usr/bin/python
print "Hello,Python!";

在这里,假设Python解释器在/usr/bin目录中可用。现在,尝试如下运行这个程序:


$ chmod +x test.py     # This is to make file executable
$./test.py

这将产生以下结果:

Hello,Python!


Python标识符:

Python标识符是用来标识一个变量,函数,类,模块或其他对象的名称一个标识符开始以字母A到Z或a〜z或后跟零个或多个字母下划线(_),下划线和数字(0〜9)。

Python中标识符内不允许标点符号,如@,$和%。 Python是一种区分大小写的编程语言。因此,Manpower 和manpower在Python中是两个不同的标识符。

这里有Python标识符命名约定:

• 类名以大写字母以及所有其它标识符以小写字母。
• 开头单个前导下划线的标识符表示由该标识符约定意思是私有的。
• 开头两个前导下划线的标识符表示一个强烈的私有的标识符。
• 如果标识符末尾还具有两个下划线结束时,该标识符是一个语言定义的特殊名称

保留字:

下面列出了在Python中的保留字。这些保留字不可以被用作常量或变量,或任何其它标识符。所有Python关键字只包含小写字母。

and exec not
assert finally or
break for pass
class from print
continue global raise
def if return
del import try
elif in while
else is with
except lambda yield

行和缩进:

一个程序员学习Python时,遇到的第一个需要注意的地方是,不使用括号来表示代码的类和函数定义块或流程控制。代码块是由行缩进,这是严格执行表示方式。

在缩进位的数目是可变的,但是在块中的所有语句必须缩进相同的量。在这个例子中,两个功能块都很好使用:

if True:
  print "True"
else:
 print "False"

然而,在本实施例中的第二块将产生一个错误

if True:
  print "Answer"
  print "True"
else:
  print "Answer"
 print "False"

因此,在Python中所有的连续线缩进的空格数同样的会结成块。以下是各种语句块中的例子:

注意:不要试图理解所使用的逻辑或不同的功能。只要确定你明白,即使他们各种模块无需括号。

#!/usr/bin/python

import sys

try:
 # open file stream
 file = open(file_name,"w")
except IOError:
 print "There was an error writing to",file_name
 sys.exit()
print "Enter '",file_finish,print "' When finished"
while file_text != file_finish:
 file_text = raw_input("Enter text: ")
 if file_text == file_finish:
  # close the file
  file.close
  break
 file.write(file_text)
 file.write("
")
file.close()
file_name = raw_input("Enter filename: ")
if len(file_name) == 0:
 print "Next time please enter something"
 sys.exit()
try:
 file = open(file_name,"r")
except IOError:
 print "There was an error reading file"
 sys.exit()
file_text = file.read()
file.close()
print file_text

多行语句:

Python语句通常用一个新行结束。 但是,Python允许使用续行字符()来表示,该行应该继续下去(跨行)。例如:

total = item_one + 
    item_two + 
    item_three

包含在[],{}或()括号内的陈述并不需要使用续行符。例如:

days = ['Monday','Tuesday','Wednesday','Thursday','Friday']

Python引号:

Python接受单引号('),双引号(“)和三(''或”“”)引用,以表示字符串常量,只要是同一类型的引号开始和结束的字符串。

三重引号可以用于跨越多个行的字符串。例如,所有下列是合法的:

word = 'word'
sentence = "This is a sentence."
paragraph = """This is a paragraph. It is
made up of multiple lines and sentences."""

Python注释:

一个井号(#),这不是一个字符串文字开头的注释。“#”号之后字符和到物理行是注释的一部分,Python解释器会忽略它们。

#!/usr/bin/python

# First comment
print "Hello,Python!"; # second comment

这将产生以下结果:
Hello,Python!


注释可能会在声明中表达或同一行之后:

name = "Madisetti" # This is again comment

你可以使用多行注释如下:

# This is a comment.
# This is a comment,too.
# This is a comment,too.
# I said that already.

使用空行:

一行只含有空格,可能带有注释,如果是空行那么Python完全忽略它。

在交互式解释器会话中,必须输入一个空的物理行终止多行语句。

等待用户

程序的下面一行显示提示,按回车键退出,等待用户按下回车键:

#!/usr/bin/python
raw_input("Press the enter key to exit.")

在这里,“ 已”被用来显示实际行之前创建两个换行。一旦用户按下键时,程序结束。这是一个很好的技巧,保持一个控制台窗口打开,直到用户完成应用程序运行。

在一行中多个语句:

分号( ; ) 允许在单行写入多条语句,不管语句是否启动一个新的代码块。下面是使用分号示例:

import sys; x = 'foo'; sys.stdout.write(x + '')

多个语句组作为套件:

一组单独的语句,在Python单一的代码块被称为序列。复杂的语句,如if,while,def,and class,那些需要一个标题行和套件。

标题行开始的声明(与关键字),并终止与冒号(:)),接着是一个或多个线构成该套件。例如:

if expression : 
  suite
elif expression : 
  suite 
else : 
  suite

命令行参数:

我们可能已经看到了,比如,很多程序可以运行,它们提供有关如何运行的一些基本信息。 Python中可以使用 -h 做到这一点:

$ python -h
usage: python [option] ... [-c cmd | -m mod | file | -] [arg] ...
Options and arguments (and corresponding environment variables):
-c cmd : program passed in as string (terminates option list)
-d   : debug output from parser (also PYTHONDEBUG=x)
-E   : ignore environment variables (such as PYTHONPATH)
-h   : print this help message and exit

[ etc. ]

您也可以设定您的脚本,它应该以这样的方式接受各种选项。 命令行参数是一个高级主题并在以后学习,当您通过其它的Python概念后。

以下是补充:

Python中查看变量对应的地址用函数id(var)。
 
注意在Python中与在C语言中有一些不同的地方。比如:a = 10,在Python中是这样的,数值10在内存中开辟一块空间来存放数据10,然后用a去引用这个10,所以这里a相当于一个标签,如果a被重新赋值了,相当于a又指向了另一个地址,比如a = 1000,那么a指向了数据1000的地址,在这点与C语言有很大的不同。
 
所以相同的数据用不同的变量去引用,它们的地址一样,比如:

a = 123     b = 123

然后我们输出id(a)和id(b)会发现这两个值完全一样

Python中的复数

   在Python中复数类型的虚部用j表示的,比如a = 3 + 4j

可以直接进行计算。
 
Python中序列的基本操作
     
(1)len()    求序列的长度
(2)+        序列拼接
(3)*        重复序列元素
(4)in       判断元素是否在序列中
(5)max()与min()    返回序列的最大值和最小值
(6)compare(str1,str2)   str1小于str2返回-1,等于返回0,大于返回1
 
元组

  a,b,c = (1,2,3)
  t = (“name”,30,”school”)
 
列表  
  list = [“name”,”school”]
可以看出,元组是用(),而列表用[],另外在元组中不能改变单个元素的值,而列表可以。
Python里面增加了**运算符和//运算符
**用于幂的计算,比如计算2的3次方,就直接a=2**3

>>> a = 2**3
>>> print a
8
>>> 

//用于向下取模,主要用于浮点数,比如3//1.7 = 1.0

>>> a = 3//1.7
>>> print a
1.0
>>> 

数字类型的内建函数

转换函数:将其他类型的数字转换为相应类型

int()、long()、float()、complex()

bool()

>>> a = 6
>>> b=complex(a)
>>> print b
(6+0j)
>>> 

功能函数

abs(num) 绝对值

coerce(num1,num2) 将num1和num2转换为同一类型,然后以一个元组的形式返回

>>> a=3.14159
>>> b=100
>>> print coerce(a,b)
(3.14159,100.0)
>>> 

divmod(num1,num2) 获得商和余数的元组

>>> a=9
>>> b=6
>>> print divmod(a,b)
(1,3)
>>> 

pow(num1,num2,mod=1) 快速幂取模运算

>>> a=2
>>> b=3
>>> print pow(a,5)
3

round(flt,ndig=1) 对浮点型进行四舍五入运算

>>> print round(3.1415926,4)
3.1416
>>> 

列表类型内建函数

list.append(obj) 向列表中添加一个对象obj
list.count(obj) 返回一个对象obj在列表中出现的次数
list.extend(obj) 把序列obj中的内容添加到列表中
list.index(obj,i=0,j=len(list)) 返回list[k]
list.insert(index,obj) 在index位置插入对象obj
list.pop(index=-1) 删除并返回指定位置的对象,认是最后一个对象
list.remove(obj) 从列表中删除对象obj
list.reversed()
list.sort()

>>> arr = [1,1,5,6,9,7,3,11,56,45,78,100,55,10]
>>> arr.append(89)
>>> print arr
[1,10,89]
>>> print arr.count(5)
2
>>> arr1 = [123,456,789]
>>> arr.extend(arr1)
>>> print arr
[1,89,123,789]
>>> arr.insert(1,999)
>>> print arr
[1,999,789]
>>> arr.pop(0)
1
>>> print arr
[999,789]
>>> arr.remove(999)
>>> print arr
[1,789]
>>> arr.sort()
>>> print arr
[0,789]
>>> 

列表有容器和可变特性
堆栈―后进先出
list.append() 向队列尾部添加
list.pop() 从队列尾部删除
队列―先进先出
list.append() 向队列尾部添加
list.pop(0) 从队列头部删除

字典类型:

访问字典中的值
通过键访问相应的值 dict2['name']
访问字典的键 dict2.keys(),返回一个列表
访问字典的值 dict2.values(),返回一个列表
遍历一个字典
执行中字典的键不能被改变
删除字典元素和字典 del dict2[name] del dict2

>>> dict = {'name':'goujinping','age':'21','sex':'man','school':'NEFU'}
>>> print dict
{'age': '21','school': 'NEFU','name': 'goujinping','sex': 'man'}
>>> dict['age']
'21'
>>> print dict['name']
goujinping
>>> print dict['age']
21
>>> for key in dict.keys():
	print key

	
age
school
name
sex
>>> for value in dict.values():
	print value

	
21
NEFU
goujinping
man
>>> del dict['sex']
>>> print dict
{'age': '21','name': 'goujinping'}
>>> del dict['school']
>>> print dict
{'age': '21','name': 'goujinping'}
>>> del dict
>>> print dict
<type 'dict'>
>>> 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用爬虫利器 Playwright,轻松爬取抖查查数据 我们先分析登录的接口,其中 url 有一些非业务参数:ts、he、sign、secret。 然后根据这些参数作为关键词,定位到相关的 js 代码。 最后,逐步进行代码的跟踪,发现大部分的代码被混淆加密了。 花费了大半天,来还原这些混淆加密的代码
轻松爬取灰豚数据的抖音商品数据 调用两次登录接口实现模拟登录 我们分析登录接口,发现调用了两次不同的接口;而且,需要先调用 https://login.huitun.com/weChat/userLogin,然后再调用 https://dyapi.huitun.com/userLogin 接口。 登
成功绕过阿里无痕验证码,一键爬取飞瓜数据 飞瓜数据的登录接口,接入了阿里云的无痕验证码;通过接口方式模拟登录,难度比较高。所以,我们使用自动化的方式来实现模拟登录,并且获取到 cookie 数据。 [阿里无痕验证码] https://help.aliyun.com/document_detail/1
一文教你从零开始入门蝉妈妈数据爬取,成功逆向破解数据加密算法 通过接口进行模拟登录 我们先通过正常登录的方式,分析对应的登录接口。通过 F12 打开谷歌浏览器的调试面板,可以看到登录需要传递的一些参数;其中看到密码是被加密了。 不过我们通过经验可以大概猜测一下,应该是通过 md5 算法加密了。 接下
抽丝剥茧成功破解红人点集的签名加密算法 抽丝剥茧破解登录签名算法,成功实现模拟登录 headers = {} phone_num = &quot;xxxx&quot; password = &quot;xxxx&quot; md5_hash = hashlib.md5() md5_hash.upda
轻松绕过 Graphql 接口爬取有米有数的商品数据 有米有数数据的 API 接口,使用的是一种 API 查询语言 graphql。所有的 API 只有一个入口,具体的操作隐藏在请求数据体里面传输。 模拟登录,获取 sessionId 调用登录接口,进行模拟登录。 cookies = {} head
我最近重新拾起了计算机视觉,借助Python的opencv还有face_recognition库写了个简单的图像识别demo,额外定制了一些内容,原本想打包成exe然后发给朋友,不过在这当中遇到了许多小问题,都解决了,记录一下踩过的坑。 1、Pyinstaller打包过程当中出现warning,跟d
说到Pooling,相信学习过CNN的朋友们都不会感到陌生。Pooling在中文当中的意思是“池化”,在神经网络当中非常常见,通常用的比较多的一种是Max Pooling,具体操作如下图: 结合图像理解,相信你也会大概明白其中的本意。不过Pooling并不是只可以选取2x2的窗口大小,即便是3x3,
记得大一学Python的时候,有一个题目是判断一个数是否是复数。当时觉得比较复杂不好写,就琢磨了一个偷懒的好办法,用异常处理的手段便可以大大程度帮助你简短代码(偷懒)。以下是判断整数和复数的两段小代码: 相信看到这里,你也有所顿悟,能拓展出更多有意思的方法~
文章目录 3 直方图Histogramplot1. 基本直方图的绘制 Basic histogram2. 数据分布与密度信息显示 Control rug and density on seaborn histogram3. 带箱形图的直方图 Histogram with a boxplot on t