我的Python之路【第一篇】:Python简介和入门
1.搭建Python环境
- windows下搭建python环境
1.下载安装包
2.Windows中Python的安装包是后缀名为msi的安装包,直接双击下一步即可
3.Windwos环境下默认的安装路径是:C:\Python27
4.添加环境变量
【右键计算机】-->【点击属性】--> 【高级系统设置】--> 【高级】--> 【环境变量】--> 【系统变量】--> 编辑Path变量 将;C:\Python27添加到其中
- 升级Linux下的Python版本
1.安装gcc
yum install gcc -y
2.下载Python2.7.11源码包
wget https://www.python.org/ftp/python/2.7.11/Python-2.7.11.tgz
3.解压压缩包
tar zxf Python-2.7..tgz
4.编译安装
cd Python-2.7.
./configure
make all
make install
5.查看安装
/usr/local/bin/python2. -V
6.修改使用的Linux使用的Python版本
mv /usr/bin/python /usr/bin/python2. ln -s /usr/local/bin/python2. /usr/bin/python
7.防止yum执行异常,修改使用的Python版本
将#!/usr/bin/python修改为#!/usr/bin/python2.6
2.Python入门
- python程序的执行过程
读取到内存 词法-->语法分析-->交给编译器-->生成字节码(pyc文件)-->装换成机器码.
注:python,java,c#这些编程语言需要先生成字节码,再转换成机器可以识别的机器码。C语言则可以直接生成机器码,这就是为什么C语言的速度比较快,但是python,java,c#这些编程语言都是通过虚拟机回收内存,而C语言则需要程序员手工回收。
- 编码问题
- python默认按照 ascill 码编码的,使用1个字节表示字符,即8位,最多只能表示2**8个字符,主要是针对西方语言的,不包含中文。所以再不声明编码字符集的情况下就会造成中文字符被输出为乱码。
- Unicode(统一码、万国码、单一码)是一种在计算机上使用的字符编码。Unicode 是为了解决传统的字符编码方案的局限而产生的,它为每种语言中的每个字符设定了统一并且唯一的二进制编码,规定虽有的字符和符号最少由 16 位来表示(2个字节),即:2 **16 = 65536。注:此处说的的是最少2个字节,可能更多
- 3.UTF-8,是对Unicode编码的压缩和优化,他不再使用最少使用2个字节,而是将所有的字符和符号进行分类:ascii码中的内容用1个字节保存、欧洲的字符用2个字节保存,东亚的字符用3个字节保存...。
- 4.utf-8节省空间,还能表示中文,所以在py文件中规定编码字符集为utf-8,声明方法有以下两种,推荐使用第一种。
# -*- coding:utf- -*-
# coding:utf-
- 注释
单行注释
# command
多行注释
"""
command1
command2
......
"""
特殊的注释要放在文件开头
#!/usr/sbin/env python
# -*- coding:ytf-8 -*-
- python的模块
python中的模块可以分为三类:
1.python自带的,如os,sys
2.业内开源的,一些大牛写的
3.自己写的模块
Python内部提供一个 sys 的模块,其中的 sys.argv 用来捕获执行执行python脚本时传入的参数
#!/usr/bin/env python
# -*- coding: utf-8 -*- import sys print sys.argv
- pyc文件
在导入自己写的模块的时候会生成一个python 的字节码 .pyc文件 ,python解释器可以识别这种文件。
# -*- coding:utf-8 -*- import m print "hello"
代码经过编译可以产生字节码;字节码通过反编译也可以得到代码。
如果把m.py删除之后first.py还能执行吗?答案是可以的,python解释器会根据m.py再次生成pyc文件。
m.py和m.pyc哪个文件的优先级高。
当m.py和m.pyc中所表示的内容是一致的,则m.pyc的优先级比较高
当m.py和m.pyc中的内容不一致的话,m.py的优先级高,会将m.py重新编译成m.pyc
- 变量
变量的命名规则
1.只能由数字,字母(大小写),下划线组成
2.变量的第一个位置不能为数字
3.以下关键字不能为变量名
['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'] 不用记 使用ide编程的时候自动报错
变量其实就是内存中的一块空间的名称,当这个变量的值改变的时候会重新分配一块内存空间。
>>> name1="chenyao"
>>> name2=name1
>>> name1
'chenyao'
>>> name2
'chenyao'
>>> name1=""
>>> name2
'chenyao'
>>> name1
''
>>>
name1和name2指向了同一块内存空间,但是再次对name1赋值之后,就又为name1开辟了一块空间。
每一次修改都要重新分配空间,所以性能不高,之前开辟的空间将会被虚拟机回收(python,java,c#)。
缓冲池
一个数据(数字,字符串,字典等)在一个可控的范围之内会指向相同的内存空间,这是py的一个优化点。 但是当超出某个范围之后就需要重新开辟空间了。
- 输入和输出
#!/usr/sbin/env python
#-*- coding:utf-8 -*-
import getpass
name=raw_input(">>>")
print name
pwd=getpass.getpass(">>>")
print pwd
getpass模块使得输入的过程不可见
- 流程控制
#!/usr/sbin/env python
#-*- conding:utf-8 -*-
name = raw_input("login name: ")
if name == "chenyao":
print "login successful"
else:
print "login failed"
if name == "eric":
print "common"
elif name == "tony":
print "super"
elif name == "chenyao":
print "god"
else:
print "shit"
嵌套
[root@muban py]# vim login3.py
#!/usr/sbin/env python
# -*- coding:utf-8 -*-
import getpass
name = raw_input("login name: ")
pwd = getpass.getpass("login password: ")
if name == "chenyao":
if pwd == "":
print "god"
print "login successful"
else:
print "login failed"
elif name == "eric":
if pwd == "":
print "common"
print "login successful"
else:
print "login failed"
elif name == "tony":
if pwd == "":
print "super"
print "login successful"
else:
print "login failed"
else:
if pwd == "":
print "shit"
print "login successful"
else:
print "login failed"
- 数据类型
整数和长整型 范围和机器的内存有关。
布尔类型
>>> i = 123
>>> type(i)
<type 'int'>
>>> j = True
>>> type(j)
<type 'bool'>
>>> j = true
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'true' is not defined
>>> j = 'true'
>>> type(j)
<type 'str'>
>>>
>>> name = 'i am chenyao , age 18'
>>> name
'i am chenyao , age 18'
>>> name = 'i am %s , age 18' % 'nuwanda'
>>> name
'i am nuwanda , age 18'
>>> name = 'i am chenyao , age %d' % 18
>>> name
'i am chenyao , age 18'
>>> name = 'i am %s , age %d' %('nuwanda',18)
>>> name
'i am nuwanda , age 18'
>>> name = 'i am %s , age %d'
>>> name %('nuwanda',18)
'i am nuwanda , age 18'
>>> print name
i am %s , age %d
>>> new_name = name %('nuwanda',18)
>>> print new_name
i am nuwanda , age 18
>>>
引号:
#!/usr/sbin/env python
# -*- coding:utf-8 -*-
print 'chen'
print "chen"
print '''
c
h
e
n
'''
列表
列表的修改不会重新开辟内存空间
>>> list=['tom','alex','jerry']
>>> list
['tom', 'alex', 'jerry']
>>> id(list)
140618237799672
>>> list1=list
>>> list1
['tom', 'alex', 'jerry']
>>> id(list1)
140618237799672
>>> list.append('chenyao')
>>> list
['tom', 'alex', 'jerry', 'chenyao']
>>> list1
['tom', 'alex', 'jerry', 'chenyao']
>>> id(list),id(list1)
(140618237799672, 140618237799672)
>>>
元组
元组不可以做添加,修改,删除的操作,其他列表的所有操作元组都可以做。
那元组作为列表的一个元素可以被修改吗?
>>> list3=['alex',('tom',jerry),'chen']
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'jerry' is not defined
>>> list3=['alex',('tom','jerry'),'chen']
>>> list3
['alex', ('tom', 'jerry'), 'chen']
>>> list3[2]
'chen'
>>> list3[1]
('tom', 'jerry')
>>> list3[1][0]
'tom'
>>> list3.append('han')
>>> list3
['alex', ('tom', 'jerry'), 'chen', 'han']
>>> list3.append(['xi','ha'])
>>> list3
['alex', ('tom', 'jerry'), 'chen', 'han', ['xi', 'ha']]
>>> del list3[-1][0]
>>> list3
['alex', ('tom', 'jerry'), 'chen', 'han', ['ha']]
>>>
字符串,列表,元组
for循环
[root@muban py]# vim for.py
#!/usr/sbin/env python
# -*- coding:utf-8 -*-
list = ['tom', 'jerry', 'jake']
for i in list:
print i
for i in list:
if i == 'jerry':
print 'it is you,',i
break
break,pass,continue
while循环
字典: 又称为键值对
字典是无序的
特殊的for循环
#!/usr/sbin/env python
# -*- coding:utf-8 -*-
person = {
"name": "chenyao",
"age": 18,
"gender": "man",
}
print person["name"]
print "#########################"
for ele in person:
print ele
print "#########################"
for ele1 in person.items():
print ele1
print "#########################"
for k,v in person.items(): 当使用for循环输出字典中的元素的时候,输出的顺序是不确定的
print k
print v
print "#########################"
print person.keys()
print person.values()
执行结果是这样的
运算:
文件的打开方式都有哪些?
r 䣧以只读模式打开文件
w 以只写模式打开文件,且先把文件内容清空(truncate the file first)
a 以添加模式打开文件,写文件的时候总是写到文件末尾,用seek也无用。打开的文件也是不能读的
r+ 以读写方式打开文件,文件可读可写,可写到文件的任何位置
w+ 和r+不同的是,它会truncate the file first
a+ 和r+不同的是,它只能写到文件末尾
我的Python之路【第一篇】:Python简介和入门的更多相关文章
- python之路第一篇
一.python环境的搭建 1.window下环境的搭建 (1).在 https://www.python.org/downloads/ 下载自己系统所需要的python版本 (2).安装python ...
- Python之路(第一篇):Python简介和基础
一.开发简介 1.开发: 开发语言: 高级语言:python.JAVA.PHP.C#..ruby.Go-->字节码 低级语言: ...
- Python之路(第九篇)Python文件操作
一.文件的操作 文件句柄 = open('文件路径+文件名', '模式') 例子 f = open("test.txt","r",encoding = “utf ...
- Python开发【第一篇】:目录
本系列博文包含 Python基础.前端开发.Web框架.缓存以及队列等,希望可以给正在学习编程的童鞋提供一点帮助!!! Python开发[第一篇]:目录 Python开发[第二篇]:初识Python ...
- Python开发【第一篇】:目录
本系列博文包含Python基础.前端开发.Web框架.缓存以及队列等,希望可以给正在学习Python编程的朋友们提供一点帮助! .Python开发[第一篇]:目录 .Python开发[第二篇]:初始P ...
- .NET持续集成与自动化部署之路第一篇——半天搭建你的Jenkins持续集成与自动化部署系统
.NET持续集成与自动化部署之路第一篇(半天搭建你的Jenkins持续集成与自动化部署系统) 前言 相信每一位程序员都经历过深夜加班上线的痛苦!而作为一个加班上线如家常便饭的码农,更是深感其痛 ...
- SAP-ABAP系列 第一篇SAP简介
第一篇 SAP简介 SAP全名为System Application and Products in Data Processing.SAP目前是全世界排名第一的RP软件,号称“全球最大的企业管理解决 ...
- Python之路第一课Day9--随堂笔记之二(进程、线程、协程篇)
本节内容 进程.与线程区别 python GIL全局解释器锁 线程 语法 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Event事件 queue队列 生产者消费者模型 Queu ...
- Python人工智能之路 - 第一篇 : 你得会点儿Python基础
Python 号称是最接近人工智能的语言,因为它的动态便捷性和灵活的三方扩展,成就了它在人工智能领域的丰碑 走进Python,靠近人工智能 一.编程语言Python的基础 之 "浅入浅出&q ...
- Python之路第一课Day6--随堂笔记(面向对象 )
本节内容: 1. 面向对象编程介绍 2. 为什么要用面向对象进行开发? 3. 面向对象的特性:封装.继承.多态 4. 类.方法 一.面向过程 VS 面向对象 1. 编程范式 编程是 程序 员 用 ...
随机推荐
- (原)SQL Server 系统提供功能的三个疑惑
本文目录列表: 1.SQL Server系统提供的部分疑惑概述2.系统函数调用时DEFAULT代替可选参数使用不统一3.队列字段列message_enqueue_time记录的是UTC日期时间 4.@ ...
- 【.Net Framework 体积大?】不安装.net framework 也能运行!?开篇叙述-1
[声明:请尊重作者micro-chen的原创,抓文章,请添加来源和作者署名.作者保留追责权利.......] 写在前言 看着日渐没落的.net ,心里多少有了点悲凉.国内的越来越多的新兴公司 都是JA ...
- Asp.net mvc 知多少(七)
本系列主要翻译自<ASP.NET MVC Interview Questions and Answers >- By Shailendra Chauhan,想看英文原版的可访问http:/ ...
- 1.使用SignalR实现页面即时刷新(服务端主动推送)
模块功能说明: 实现技术:sqlserver,MVC,WebAPI,ADO.NET,SignalR(服务器主动推送) 特殊车辆管理--->移动客户端采集数据存入数据库---->只要数据库数 ...
- DataReader的用法程序简析
// 2015/07/05 using System; using System.Collections.Generic; using System.Linq; using System.Text; ...
- [Netty] - Netty入门(最简单的Netty客户端/服务器程序)
Java中的NIO是一种解决阻塞式IO问题的基本技术,但是NIO的编写对java程序员是有比较高的要求的.那么Netty就是一种简化操作的一个成熟的网络IO编程框架.这里简单介绍一个程序,代码是< ...
- JavaScript中国象棋程序(6) - 克服水平线效应、检查重复局面
"JavaScript中国象棋程序" 这一系列教程将带你从头使用JavaScript编写一个中国象棋程序.这是教程的第6节. 这一系列共有9个部分: 0.JavaScript中国象 ...
- 第二章:JavaScript对象
一.window对象 1.属性 2.方法 二.history对象 1.方法 三.location对象 1.属性 2.方法 四.Document对象 1.属性 2.方法
- Tinychatserver: 一个简易的命令行群聊程序
这是学习网络编程后写的一个练手的小程序,可以帮助复习socket,I/O复用,非阻塞I/O等知识点. 通过回顾写的过程中遇到的问题的形式记录程序的关键点,最后给出完整程序代码. 0. 功能 编写一个简 ...
- 前端性能监控:window.performance
window.performance 是W3C性能小组引入的新的API,目前IE9以上的浏览器都支持.一个performance对象的完整结构如下图所示: memory字段代表JavaScript对内 ...