python学习笔记(一)之入门
1、python的安装
官网下载.exe文件直接安装即可,在安装过程中选择加入环境变量,就不用在安装后再去增添环境变量了。
本文选择的是python3.6版本,没有选择2.7版本。
2、启动python解释器和运行.py文件
安装过程中选择创建桌面图标连接,在安装过后可以直接点击图标即可,或者在cmd下输入python即可。
我们可以看到如下图所示内容:
Python 3.6.3 (v3.6.3:2c5fed8, Oct 3 2017, 18:11:49) [MSC v.1900 64 bit (AMD64)] on win32
Type "copyright", "credits" or "license()" for more information.
>>>
在python解释器中>>>是主提示符,...是次要提示符。
>>> str = '''python
...is cool!'''
>>> print(str)
python
is cool!
python程序文件是以.py结尾,运行该文件可以在cmd中转到代码目录,然后使用以下命令即可:
> python filename.py
也可以使用各种编辑器如pycharm,可以在编辑器中直接执行。
3、print语句和“Hello World!”
在python3.6 版本中,print语句采用print()的形式。
#!/usr/bin/env python
# _*_coding:utf-8_*_
# name:'first.py'
print('Hello World!')
执行first.py
> python first.py
Hello World!
也可以直接打开python解释器直接输入:
>>> print('Hello World!')
Hello World!
在解释器中“_”有着特别的意义:表示最后一个表达式的值,是表达式而不是普通语句。
>>> _
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name '_' is not defined
>>> str = 'Hello World!'
>>> str
'Hello World!'
>>> _
'Hello World!'
print语句的标准化输出
采用的是类似于C语言的printf()类似的写法:
>>> print('I want to say %s' % (str))
I want to say Hello World!
此外,在了解到stdout:
>>> import sys
>>> sys.stdout.write('Hello World!')
Hello World!>>>
这里的sys.stdout.write()不会在句尾自动回车。
疑问
在学习到标准化输出时,了解到重定向,采用的是linux中的>>符号:
运行下一段代码时出现错误:
#!/usr/bin/env python
import sys
logfile = open('log.txt', 'w+')
ser = sys.stderr
print >> logfile, 'Hello World!'
print >> ser, 'stderr'
logfile.close()
输出错误:
Hello World!
Traceback (most recent call last):
File "G:/Code/python/fan.py", line 6, in <module>
print >> logfile, 'Hello World!'
TypeError: unsupported operand type(s) for >>: 'builtin_function_or_method' and '_io.TextIOWrapper'. Did you mean "print(<message>, file=<output_stream>)"?
Process finished with exit code 1
怀疑是平台的问题,之后再linux上测试了一下,没有问题:
$ python fan.py
stderr
$ cat log.txt
Hello World!
至于具体原因还不知,望哪位大神告知!
输入与input()内建函数
python使用input()函数进行程序输入,它读取标准输入,并将读取到的数据复制给指定的变量。在这之中你可以使用int()内建函数将用户输入的字符串转换为整型。
>>> name = input('Please input your name:')
Please input your name:yt
>>> num = input('Please input your num:')
Please input your num:22
>>> print('Your name is %s' % (name))
Your name is yt
>>> print('Your age is %d' % (num))
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: %d format: a number is required, not str
>>> print('Your age is %d' % (int(num)))
Your age is 22
>>> print('Your age is %s' % (num))
Your age is 22
可见input()得到的标准化输入为字符串,当需要整型数值是需要使用int()内建函数。可以使用help(input)查看帮助信息:
>>> help(input)
Help on built-in function input in module builtins:
input(prompt=None, /)
Read a string from standard input. The trailing newline is stripped.
The prompt string, if given, is printed to standard output without a
trailing newline before reading input.
If the user hits EOF (*nix: Ctrl-D, Windows: Ctrl-Z+Return), raise EOFError.
On *nix systems, readline is used if available.
在python2中使用的是raw_input()函数,查看帮助信息会发现其标准化输入为字符串,输出也为字符串:
Help on built-in function raw_input in module __builtin__:
raw_input(...)
raw_input([prompt]) -> string
Read a string from standard input. The trailing newline is stripped.
If the user hits EOF (Unix: Ctl-D, Windows: Ctl-Z+Return), raise EOFError.
On Unix, GNU readline is used if enabled. The prompt string, if given,
is printed without a trailing newline before reading.
(END)
注释
python使用的和其他的unix-shell脚本的注释一样都是:#.
# Author:yt
# 标注作者
此外,在函数中的注释使用的是双引号;
#!/usr/bin/env python
def test(x):
"This is a test function"
print('The result is %d' % (x+x))
test(1)
$ python3 fan.py
The result is 2
需要注意最好在脚本开始加上这两句代码:
#!/usr/bin/env python 指定代码执行程序
# _*_coding:utf-8_*_ 指定编码格式
操作符
主要包括算术操作符、比较操作符和逻辑操作符。
算术操作符:
+ 加
- 减
/ 算术除
* 乘
// 相除取整
% 取余
** 乘方
>>> 5/3
1.6666666666666667
>>> 5//3
1
>>> 5%3
2
>>> 5**3
125
比较操作符:
< > == <= >= != <>
python目前支持两种不等于比较操作符,但是对于2和3支持却不相同:
$ python
Python 2.7.13 (default, Mar 13 2017, 20:56:15)
[GCC 5.4.0] on cygwin
Type "help", "copyright", "credits" or "license" for more information.
>>> 5!=1
True
>>> 5<>1
True
----------------------------------------------------------
$ python3
Python 3.6.1 (default, Mar 21 2017, 21:49:16)
[GCC 5.4.0] on cygwin
Type "help", "copyright", "credits" or "license" for more information.
>>> 5!=1
True
>>> 5<>1
File "<stdin>", line 1
5<>1
^
SyntaxError: invalid syntax
逻辑操作符:
and or not
有一个特殊的现象:
True
>>> 3<4 and 4<5
True
变量与赋值
python的变量名是大小敏感的,其命名是以字母开头,大小写皆可,在加上数字和下划线。
python是动态语言,不需要预先声明变量的类型,其类型和值在被赋值的那一刻就已经被初始化了。
python支持增量赋值,即:
>>> n = 10
>>> n += 10
>>> n
20
但是并不支持自增与自减。
数字
主要包括:有符号整型、长整型、布尔值、浮点值和复数
eg:
long 27879898L -7867L
complex 6.23+1.5j 0+1j 1+0j
其中长整型在3.6版本应该发生了变化:
$ python3、
Python 3.6.1 (default, Mar 21 2017, 21:49:16)
[GCC 5.4.0] on cygwin
Type "help", "copyright", "credits" or "license" for more information.
>>> nj = 1231321L
File "<stdin>", line 1
nj = 1231321L
^
SyntaxError: invalid syntax
-----------------------------------------------------------
$ python
Python 2.7.13 (default, Mar 13 2017, 20:56:15)
[GCC 5.4.0] on cygwin
Type "help", "copyright", "credits" or "license" for more information.
>>> nj = 182391283L
>>>
更具体的需要去查询文档。
此外还包括第六种数字类型:decimal用于十进制浮点数,python2.4之后已经增加了。
>>> import decimal
>>> decimal.Decimal(1.1)
Decimal('1.100000000000000088817841970012523233890533447265625')
>>> print(decimal.Decimal('1.1'))
1.1
字符串
Python中的字符串被定义为引号之间的字符集合。python支持使用成队的单引号或者双引号,三引号可以用来包含特殊字符。使用索引和切片可以得到子字符串。字符索引从0开始,最后一个字符索引为-1.
#!/usr/bin/env python
# _*_coding:utf-8_*_
str1 = "python"
str2 = "cpython"
print(str1)
print(str2)
print(str1[::-1])
for i in range(len(str1)):
print(str1[i])
for i in range(len(str2)):
print(str2[:i+1])
输出:
C:\Users\yanta\AppData\Local\Programs\Python\Python36\python.exe G:/Code/python/1.py
python
cpython
nohtyp
p
y
t
h
o
n
c
cp
cpy
cpyt
cpyth
cpytho
cpython
Process finished with exit code 0
列表和元组
列表和元组可以当成普通的“数组”,能够保存任意数量的任意类型的Python对象。和数组一样,可通过数字索引访问元素,且索引从0开始。依然可以切片运算。
区别:list用中括号[]包裹,元素个数和值可以改变。tuple是使用小括号()包裹,不可改变,可以看成只读的列表。
list = [1, 2, 3, 4]
tuple = ('a', 'b', 'c', 'd')
print(list[::-1])
print(tuple[::-1])
for i in range(len(list)):
print(list[i])
for i in range(len(tuple)):
print(tuple[i])
for i in range(len(list)):
print(list[:i+1])
for i in range(len(tuple)):
print(tuple[:i+1])
输出结果:
[4, 3, 2, 1]
('d', 'c', 'b', 'a')
1
2
3
4
a
b
c
d
[1]
[1, 2]
[1, 2, 3]
[1, 2, 3, 4]
('a',)
('a', 'b')
('a', 'b', 'c')
('a', 'b', 'c', 'd')
字典
字典是python的映射数据类型,有键值对构成。值可以为任意类型的python对象,字典元素用大括号({ })包裹。
# 字典
dict = {'name': 'yt', 'age': '17'}
print(dict.keys())
dict['name'] = 'boy'
print(dict)
for key in dict:
print(dict[key])
输出结果:
dict_keys(['name', 'age'])
{'name': 'boy', 'age': '17'}
boy
17
这里的dict.keys()在2.7和3.6版本中有所变化:
Python 2.7.13 (default, Mar 13 2017, 20:56:15)
[GCC 5.4.0] on cygwin
Type "help", "copyright", "credits" or "license" for more information.
>>> dict = {'name': 'yt', 'age': '17'}
>>> dict.keys()
['age', 'name']
-----------------------------------------
$ python3
Python 3.6.1 (default, Mar 21 2017, 21:49:16)
[GCC 5.4.0] on cygwin
Type "help", "copyright", "credits" or "license" for more information.
>>> dict = {'name': 'yt', 'age': '17'}
>>> dict.keys()
dict_keys(['name', 'age'])
代码块缩进对齐
python的代码块书写时不要靠小括号(())和花括号({ })来区分代码块区域的,而是直接使用缩进的方式,通用的缩进距离是4。
在解释器中输入代码也要注意缩进:
>>> for i in range(3):
... print(i) #无缩进
File "<stdin>", line 2
print(i)
^
IndentationError: expected an indented block
>>> for i in range(3):
... print(i) #有缩进
...
0
1
2
语句
if语句
语法如下:
if expression:
pass
特别注意缩进和if语句后的:.
if expression1:
pass1
elif expression2:
pass2
else:
pass3
while循环
语法如下:
while expression:
pass
for循环
python中的for循环与传统的for循环不一样,更像shell脚本中的foreach迭代。每次选取迭代对象中的一个。
>>> for i in [1, 2, 3, 4]:
... print(i)
...
1
2
3
4
此外,for循环经常与range()内建函数一起使用:
list = ['a', 'b', 'c', 'd']
for i in range(3):
print(i)
for i in range(len(list)):
print(list[i])
输出结果:
0
1
2
a
b
c
d
列表解析
就是你可以在这一行中使用一个for循环将所有的值放到一个列表中;
>>> [x**2 for x in range(4)]
[0, 1, 4, 9]
还可以加入过滤条件:
>>> [x**2 for x in range(4) if not x%2]
[0, 4]
>>> [x**2 for x in range(4) if x%2]
[1, 9]
文件与内建函数open()
python可以进行文件访问:
open()函数可以打开文件,并且可以指定使用什么方式:
myfile = open('filename', 'r,w,a,b,[+]')
其中‘+’表示读写,‘b’表示二进制,默认为‘r’。如果执行成功,一个文件对象句柄会被返回。后续文件操作必须通过此文件句柄进行。
文件对象有一些方法,如readlines()和close(),通过句点标识法访问。
logfile = open('log.txt', 'r')
for eachline in logfile:
print(eachline)
logfile.close()
执行结果:
$ python3
Python 3.6.1 (default, Mar 21 2017, 21:49:16)
[GCC 5.4.0] on cygwin
Type "help", "copyright", "credits" or "license" for more information.
错误与异常
主要就是将代码封装进入try-except语句中就可以了。try之后是你打算管理的代码,expect之后则是处理错误的代码。
# python3.6
try:
logfile = open('log.txt', 'r')
for eachline in logfile:
print(eachline)
logfile.close()
except IOError:
print('file open error')
# python2.7
try:
logfile = open('log.txt', 'r')
for eachline in logfile:
print(eachline)
logfile.close()
except IOError, e:
print('file open error:', e)
从商可以看到两个版本中还是有多不同的,也可以使用as来达到同样的效果:
try:
logfile = open('log.txt', 'r')
for eachline in logfile:
print(eachline)
logfile.close()
except IOError as e:
print('file open error', e)
当删除log.txt后可以看到异常:
file open error [Errno 2] No such file or directory: 'log.txt'
此外在还可以增加else语句,else语句表示当没有异常,try后代码语句执行成功后,执行else后的语句;而且在执行异常处理expect语句后可以执行再finaily语句。
try:
logfile = open('log.txt', 'r')
for eachline in logfile:
print(eachline)
logfile.close()
except IOError as e:
print('file open error', e)
else:
print('Open log.txt sucessful!')
finally:
print('IOError ...')
输出结果:
$ python3
Python 3.6.1 (default, Mar 21 2017, 21:49:16)
[GCC 5.4.0] on cygwin
Type "help", "copyright", "credits" or "license" for more information.
Open log.txt sucessful!
函数
定义函数语法:
def functionName([arguments]):
"说明语句"
pass
调用函数:
functionName(arg)
此外,参数可以设置默认值
def test(name = 'yt'):
print(name)
test('hehe')
test()
测试结果:
hehe
yt
类
定义类语法:
class ClassName(base_class[es]):
"optional documentation string"
static_member_declarations
method_declarations
eg:
class test(object):
name = 'yt'
def __init__(self, num = 17):
self.age = num
print('age is ', num)
def show(self):
print(self.name, ' is ', self.age, 'years old!')
print(self.__class__.__name__)
foo = test() #定义类后需要创建实例
foo.show() #再调用方法
输出:
age is 17
yt is 17 years old!
test
模块
模块实际上就是一个python程序文件,包括可执行代码、函数和类或者其他的东西组合。
当你创建一个python源文件,模块的名字就是不带.py后缀的文件名。
模块的导入方法:
import module
from module improt method
eg:
>>> import sys
>>> sys.stdout.write('Hello World!')
>>> Hello World!
补充
dir([obj]):描述对象的属性,如果没有提供参数,则会显示全局变量的名字
>>> dir(3)
['__abs__', '__add__', '__and__', '__bool__', '__ceil__', '__class__', '__delattr__', '__dir__', '__divmod__', '__doc__', '__eq__', '__float__', '__floor__', '__floordiv__', '__format__', '__ge__', '__getattribute__', '__getnewargs__', '__gt__', '__hash__', '__index__', '__init__', '__init_subclass__', '__int__', '__invert__', '__le__', '__lshift__', '__lt__', '__mod__', '__mul__', '__ne__', '__neg__', '__new__', '__or__', '__pos__', '__pow__', '__radd__', '__rand__', '__rdivmod__', '__reduce__', '__reduce_ex__', '__repr__', '__rfloordiv__', '__rlshift__', '__rmod__', '__rmul__', '__ror__', '__round__', '__rpow__', '__rrshift__', '__rshift__', '__rsub__', '__rtruediv__', '__rxor__', '__setattr__', '__sizeof__', '__str__', '__sub__', '__subclasshook__', '__truediv__', '__trunc__', '__xor__', 'bit_length', 'conjugate', 'denominator', 'from_bytes', 'imag', 'numerator', 'real', 'to_bytes']
>>> dir()
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'dict', 'i']
python学习笔记(一)之入门的更多相关文章
- Python学习笔记——jupyter notebook 入门和中文pdf输出方案
简单粗暴的安装 对于懒人而言,我还是喜欢直接安装python的集成开发环境 anaconda 多个内核控制 jupyter官网 1). 同时支持python2 和python 3 conda crea ...
- python学习笔记--Django入门四 管理站点--二
接上一节 python学习笔记--Django入门四 管理站点 设置字段可选 编辑Book模块在email字段上加上blank=True,指定email字段为可选,代码如下: class Autho ...
- python学习笔记--Django入门0 安装dangjo
经过这几天的折腾,经历了Django的各种报错,翻译的内容虽然不错,但是与实际的版本有差别,会出现各种奇葩的错误.现在终于找到了解决方法:查看英文原版内容:http://djangobook.com/ ...
- VS2013中Python学习笔记[Django Web的第一个网页]
前言 前面我简单介绍了Python的Hello World.看到有人问我搞搞Python的Web,一时兴起,就来试试看. 第一篇 VS2013中Python学习笔记[环境搭建] 简单介绍Python环 ...
- OpenCV之Python学习笔记
OpenCV之Python学习笔记 直都在用Python+OpenCV做一些算法的原型.本来想留下发布一些文章的,可是整理一下就有点无奈了,都是写零散不成系统的小片段.现在看 到一本国外的新书< ...
- 近期Python学习笔记
近期Python 学习笔记--一篇文入门python 作者:Pleiades_Antares(www.cnblogs.com/irischen) 写在前面的话 想学Python已经许久,一年多以前(应 ...
- python学习笔记目录
人生苦短,我学python学习笔记目录: week1 python入门week2 python基础week3 python进阶week4 python模块week5 python高阶week6 数据结 ...
- tensorflow学习笔记二:入门基础 好教程 可用
http://www.cnblogs.com/denny402/p/5852083.html tensorflow学习笔记二:入门基础 TensorFlow用张量这种数据结构来表示所有的数据.用一 ...
- Python学习笔记总结
目录 Python学习笔记总结 前言 安装 数据类型 Hello,World 变量 字符串 首字母大写 全部小写 全部大写 Tab和换行符 格式化 去除空格 List列表 列表增删改查排序 遍历列表 ...
- python学习笔记整理——字典
python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...
随机推荐
- Markdown例
一个例子: 例子开始 1. 本章学习总结 今天主要学习了三个知识点 封装 继承 多态 2. 书面作业 Q1. java HelloWorld命令中,HelloWorld这个参数是什么含义? 今天学了一 ...
- 市场主流5款HTML5开发框架详解
我们经常听见的前端框架是一个非常大的范词,因为前端框架都是基于JS.CSS.HTML5技术开发实现的,不过选择一个HTML5开发框架需要考虑哪些方面,首先就是需要什么样的功能,其次就是技术实现,不过当 ...
- PowerBI开发 第五篇:关系的设计
PowerBI 使用 内存的列式数据库 VertiPaq,用于对已发布的数据集进行数据压缩和快速处理,能够使PowerBI报表执行脱机访问,面向列的处理,高度优化对1:N关系的处理性能.PowerBI ...
- 基于maven的profile实现动态选择配置文件
需求 根据选择不同的部署环境自动替换相关配置变量,如连接的数据库等. 最终效果概览 部署环境分为dev和release 工程目录结构 myproject |-profile | |-dev | | | ...
- IDEA导入Eclipse项目 【未结束的注释、非法类型的开始、缺少符号】
如果我们导入Eclipse项目的使用出现了未结束的注释.非法类型的开始.缺少符号这么一些编译时期的错误,而我们的代码明明看起来就是正常的-. 我们去检查一下是否编码的问题:把FileEncoding全 ...
- Jacoco远程统计tomcat服务(Windows系统)的代码覆盖率
Jacoco远程统计tomcat服务(Windows系统)的代码覆盖率 2017-09-21 目录 1 Jacoco的安装和设置 1.1 什么是Jacoco? 1.2 Jacoco安装 1.3 ...
- 用vue开发一个app(1,基础环境配置)
在今天之前,我没有很系统的看过,学习过vue.也是第一次尝试用vue写个小应用 现在开始研究配环境 这边参考的是https://cn.vuejs.org/v2/guide/installation.h ...
- zookeeper环境搭建及使用
本文只讲解搭建步骤,先不讲原理相关知识 一.zookeeper下载地址 本文使用版本为zookeeper-3.4.10.tar.gz 地址:http://mirrors.shuosc.org/apac ...
- gRPC官方快速上手学习笔记(c#版)
上手前准备工作 支持操作系统:windows.OS X.Linux.实例采用.net..net core sdk. The .NET Core SDK command line tools. The ...
- JS设计模式(一) 单例模式
命名空间 单例模式是JavaScript中最常见的一种模式,通过这种模式可以为我们提供一个命名空间,例如jQuery库的命名空间为jQuery或$.命名空间的使用是为了让代码更加整洁,在多人协作开发的 ...