与python的第一次邂逅

时间:2022-10-20 16:23:08

python简介

 

一.什么是python

  • python是一种面向对象、直译式的计算机程序语言,所以有了武老师的那句名言:一切皆为对象
  • python的设计哲学是:“优雅”,“明确”,“简单”
  • python那些能做的事:web程序,GUI开发,自动化运维,领域涉及到数据分析,量化投资,系统编程,组件集成。网络服务,图像处理,数值计算和科学计算,自动化测试,爬虫

 

二.和其他语言的对比

  1.python自身的优缺点:

  • python是一种全栈语言,不仅可以做前端,还可以做后端,并且开发效率高,同样的功能比其他语言少得多的代码,而且python拥有丰富的类库,由于其设计哲学,所以python的代码犹如阅读美文样具有易读性

  • 由于python还是一种不成熟的语言,在处理多线程进程表现的不是很完美

  2.其他语言的优缺点:

  • c语言被认为是最基层的语言,和机器直接打交道,代码直接转换成机器码,执行效率高是无可厚非的,而python等语言首先要把代码编译成字节码,然后再编译成机器码,中间就多了那么一步
  • 不过,c语言对内存的拿与放需要频繁的操作,另外提供线程的功能比较少(其实大多数的语言都是基于c语言来做的,而且这些语言的出现就是对c语言的某些方面进行优化,例如java,c#,php,也包括现在讲的python)
  • PHP在前端web网站有着先天性的优势,而在后端,却显得那么憔悴无力,而python做前端和后端都是非常的方便,比如数据分析方向

 

三.python的种类和区别

  • 由于python比较火,各大语言都开发了自己版本的python,比如jpython就是Java开发的,rubypython就是ruby开发的...这些不同版本的python都用的是同一套规则
  • 另外,它们唯一的不同就是,代码编译过程都是用自己语言的编译器,比如,jpython就是用Java的编辑器把代码编译字节码的,有一个pypy版的python,它的代码是直接转换成机器码,执行效果高,主要常见于微线程,不过我们现在用是的cPython

 

编程要求

 

一.语法要求

  • 统一缩进:同一级代码必须保持一致!(建议是每次缩进4个空格)

 

二.变量命名

  • ›命名规则›1.只能包含字母、数字、下划线(python对大小写敏感)›2.不能以数字开头›3.不能是python中定义的关键字

 

python的安装与更新

 

一.安装python

 

  • 下载安装包:https://www.python.org/downloads/
  • 安装默认路径:C:\python3.5
  • 配置环境变量:  【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》【在第二个内容框中找到 变量名为Path 的一行,双击】 --> 【Python安装目录追加到变值值中,用 ; 分割】
  • linux:linux自带,无需安装

 

二.更新python

 

  • windows:卸载重装即可
  • linux:
  • 查看默认Python版本
    python -V

    1、安装gcc,用于编译Python源码
        yum install gcc
    2、下载源码包,https://www.python.org/ftp/python/
    3、解压并进入源码文件
    4、编译安装
        ./configure
        make all
        make install
    5、查看版本
        /usr/local/bin/python2.7 -V
    6、修改默认Python版本
        mv /usr/bin/python /usr/bin/python2.6
        ln -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

 

一.执行方式

  •   解释器编写
  •   文件编写,在终端执行文件(python 路径)
  •   指定python解释器的路径 #! /usr/bin/env python

 

二.写下第一句代码

print('hello world')

   print 打印(python2.7可以不加括号,但python3一定要加)

 

三.编码

  •   ascii码,8位制,由于计算机语言发明时只考虑了发明者国家的文字语言
  •   unicode,万国码,兼收了多国的文字语言,至少用两个字节,其中汉字3个字节(弊端:占内存)
  •   gbk和utf-8,对Unicode加工归类,精简
  •   # -*- coding:utf-8 -*-    告诉程序用什么编码(py2.7用中文加上这行就是默认ascii转换,py3.0默认utf-8)

 

四.初识模块和字节码

  •   虽然在python的执行方式中的执行文件扩展名可以.txt或.py,但为了规范,统一.py
  •   单行注释用#(快捷键--ctrl+/),多行注释用三引号
  •   import 文件名(等同吧这个文件名的代码导入到了当前程序)
  •   文件代码执行过程中就伴随字节码文件的生成.pyc,而且执行时优先找.pyc文件,找不到再找源文件,根据源文件生成一个.pyc文件,然后再执行.pyc文件

 

五.用户交互

  •   交互器:py2.7是raw_input,py3.0是input
username = input('please input your username:')
passward = input('please input your passward:')
print('用户名:',username,'密码为:',passward)
  •  输入的结果为:用户名: 拍省先生 密码为: 123

 

六.编写流程梳理

  •   创建xxx.py文件(文本文件改名)--注:不要有中文路径
  •   写代码:1.头两行(指定解释器,指定文件编码) 2.功能代码
  •   执行代码:1.打开中终端  2.python 文件路径python
  •       python编码转换图

与python的第一次邂逅

#在python2.7中编码转换有一个中转过程
#
windows终端能对unicode编码自动转换成默认类型gbk
#
temp = '李杰'
#
解码,需要指定原来是什么编码
#
temp_unicode = temp.decode('utf-8')
#
temp_gbk = temp_unicode.encode('gbk')
#
print(temp_gbk)

#而在python3.5中不用人为中转了,程序会自动转换,
#
而且在python3移除了python的unicode的类型
temp = '李杰'
temp_gbk
= temp.encode('gbk')
print(temp_gbk) #结果为b'\xc0\xee\xbd\xdc'

 

 

七.初识python数据类型

  •   数字:age = 18
  •   字符串: a1 = ’after‘    只要是英文单引、双引、三引引起来的内容
  •   布尔值: Ture/False(因为python对字母大小写敏感,所以要注意布尔值的首字母要大写)

 

八.python变量与内存

与python的第一次邂逅与python的第一次邂逅

 

name1 = 'wupeiqi' 
print(id(name1)) #结果为11911888
name2 = name1
print(id(name1),id(name2)) #结果为11911888 11911888
name2 = 'alex' print(id(name2)) #结果为11914576

  当name1和name2等于同一个值,显示为指向同一个内存地址,而name2等于另外一个值时,name1和name2指向的内存地址就不同了,从中得出,python是根据值来开辟内存空间的

 

九.基本条件语句

 1.语法格式if 条件:

          内容1
          内容2
       else:
          内容3

          内容4

 2.同级别保持同样的缩进

 3.执行规则:按顺序来,先满足先执行,后满足不执行

n1 = 1
n2
= 2
if n1 < n2:
  
print('yes')
else:
  
print('no')

 

name = input('username:')
pwd
= input('passward:')
if name == 'alex' and pwd == '123':
print('yes')
else:
print('no')

  4.if...elif...else结构

    if 条件:
      代码块
    elif 条件:
      代码块
    else:
      代码块

 

inp = input('>>>')
if inp == '1':
print('111')
elif inp == '2':
print('222')
elif inp == '3':
print('333')
else:
print('....')

 

十.while 循环

  语法结构:

while condition:      #条件不成立是跳出循环
do someting #又叫循环体

  如果条件一直成立,那么就会一直循环下去,称为死循环

import time
n1
= True
while n1: #如果条件一直为真,就发生死循环
print('1')
time.sleep(
1) #如果不确定是不是死循环,可以用time来延迟消耗内存的时间
n1 = False #改变循环条件,让循环退出
print('end')

   好,我们来看个小实例:输出10以内的所有的正整数

    1.第一个可以通过控制循环的条件来输出自己想要的数

n = 1
while n < 11:
print(n)
n
= n + 1
print('End')

    2.设置标识符来控制条件

import time
kaishi
= 1
flag
= False #你知道吗?这就是传说中的标识符
while flag:
print(kaishi)
if kaishi == 10: #标识符起作用前要先判断下
flag = False #当标识符再次出现,循环就要退出了
kaishi = kaishi + 1 #循环计数器,也叫迭代器
time.sleep(1) #这是预防死循环的有效缓冲机制
print('End')

  3.好的,那么我们接下来介绍一下,一对双胞胎兄弟:break和continue

    •   这两个小兄弟是干嘛的呢?都有中断循环的天生能力
    • 不过,break力气大了点,一力中断了整个循环,而continue只中断本次循环,进入下次循环

    好,那掌声响起,看看break这个兄弟的精彩的表演吧

kaishi = 1
while True:
print(kaishi)
if kaishi == 10:
break
kaishi
= kaishi + 1

    看到没,等于10时就跳出真个循环了

    好!接下来是continue兄了,等等,由于你只中断本次循环,进入下次循环,所以你更容易进入死循环,所以我请来time兄来给你助阵,可以开始了

import time
while True:
print('123')
time.sleep(
0.2)
continue
print('456')

    你看,continue兄开始自己打转转了,一直输出123,它后面的456都看不到

    不过这这两兄弟搭配干活,简直就是绝配啊,来,我们瞧瞧吧

    现场有人给这两兄弟出了一道难题,就是你把1-10,不过不包7的数字输出

i = 1
while True:
if i == 7:
i
+=1
continue
print(i)
if i == 10:
break
i
+= 1

    漂亮,它们做到了,真是一对黄金搭档啊

                                                           欢迎大家对我的博客内容提出质疑和提问!谢谢

                                                           笔者:拍省先生