python one 1

老男孩python第一节课笔记博客

首先老师开课激励,一起吹了会牛逼,然后自我介绍等等,下面进入正题,

首先是python介绍

1.介绍

python的创始人为吉多·范罗苏姆(Guido van Rossum)。1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承。

python对于我来说是一门准备进入开发圈的敲门砖,由于python是由c转变而来,所以学会python就可以更快速学习其他语言。而且python相比其他语言相对简单,对于我这个高中生最好不过,不过老男孩的第一节课还是让我学的死去活来,有时懵逼有时清醒。不扯了转会正题

1.首先说一下python与其他语言的对比

在许多语言中,C语言的运行速度是最快的,其他语言大部分都是由C语言开发出来,C语言在交给机器的时候是直接把代码转换为机器码,而其他语言比如python、java就比c多一部,那就是先把代码转换为字节码,然后转换为机器码,交给机器运行。但是c和java都是比较难学,耗时的语言,所以简洁的python就最好不过了。

2.python的编译种类

- CPython把源码交给c字节码运行    代码 -> C字节码 -> 机器码 (一行一行转换,浪费系统资源和时间)

- pypy: 把源码交给python字节码运行     代码 -> C字节码 -> 机器码 全部转换完 -> 执行 (把代码统一转换为字节码,然后统一运行,编译时慢,运行快)

- 其他Python如jpython编译成java字节码运行   代码 -> 其他字节码 -> 机器码

正题安装python

官网下载: https://www.python.org/downloads/

安装最新版3.6 下载强大的python工具pychram(英文名:排插m)https://www.jetbrains.com/pycharm/download/#section=windows    下载专业版,激活码找度娘

安装完成后设置:

a.选择file->new progect

location选择存放路径  lnterpreter选择python位置     然后create创建

b.右键新建的项目新建文件夹和python文件

c.设置文件编码选择file->default settings搜索栏输入coding->选择file encodings把里面所有编码改成utf-8,保存

e.设置python文件模板选择file->default settings搜索栏输入temp->editor->file and code templates找到python script 在右边大白色区域输入

#!/usr/bin/python      (设置python在linux调用那个解释器)

#-*- coding:utf-8 -*-  (设置解释器使用那种编码读取这个文件)

这两行必须写在文件开头

理论开始

python编码:

utf-8 国际通用编码,是万国码的简化版(对万国码压缩 :a  00000010)

万国码 国际编码,由于字母汉字等占用太大空间,已被utf-8代替   (存储(至少16位) :a  00000000 00000010            中 10000000 00000000)

gbk   gb2312    中文专属,不利于后期公司国际化 占用空间小

(如中文:龙

utf-8,需要使用三个字节来表示 24   10000000 00000000 00000010

gbk,  需要使用二个字节来表示 16   00100110 00000010)

PS:Python编码相关:

- 文件编码

- Python解释器编码(py3 utf-8)   # -*- coding:utf-8 -*-

- Python解释器编码(py2 ascii)

python解释器:

windows:从官网下载的python,安装完成后为官方默认解释器,在cmd命令行输入python可调用或者找到安装好的python执行py文件

如C:\Python35\python.exe D:\1.txt     python文件后缀只是表示作用,推荐改为.py

linux:linux系统默认安装python升级为3.6需要update一下,同样在命令行输入python即可调用,执行py文件需要./文件名,前提是文件首已经写入#!/usr/bin/python已经有执行权限,不然以python 加文件名运行

3、与其他语言对比

对比C语言减少了学习成本

对比Java语言减少了代码,(如java写1000行,python只需要写100行)

写python:

1、注释

注释一行 #内容

多行注释 """内容"""

排查m快捷键ctrl加?号

2、使用模块

(python中有许多模块可以调用,使开发更简洁。类库有三种:python内部提供、业内开源模块、自己写模块)如:

#!/usr/bin/python

#-*- coding:utf-8 -*-

import sys   #调用模块

print sys.argv  #输出sys模块内的参数

3、输入输出

input #输入

print #输出    如

a = input(‘请输入用户名:‘) #设置变量a,并输入内容

import getpass #导入getpass模块

a = getpass.getpass (‘请输入密码:‘) #设置变量a,getpass模块用于隐藏输入内容

print (a) #输出变量a

4、变量

什么是变量,就是把一串字符串简化为一个或多个字母,减少开发不必要的工作两

变量名设置要求:

字母可以使用   如:asd

数字可以使用(但不能以数字开头) 如:a2

下划线可以使用 如:a_d

不可以使用关键字(python内置一部分关键字[‘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‘]

潜规则:在python中变量写法按照user_id方便后期查看区分

变量赋值,一个变量会在内存中开辟一个空间用于存储变量的赋值,不同名称的赋值会开辟不同空间。如果变量赋值相同,python内置优化机制会让两个变量名都指向同一块空间,以节省内存空间。

条件语句:

1、if判断

格式:  if 条件:

成功走这

else:

失败走这

如:

import getpass   #导入getpass模块

name = input (‘请输入用户名:‘) #设置变量,输入内容

pwd  = getpass.getpass (‘请输入密码:‘) #设置变量,使用getpass输入密码并隐藏密码

if name == ‘liuming‘ and pwd == ‘123456‘: #判断name是否等于liuming,pwd是否等于123456

print(‘欢迎登陆‘) #判断匹配输出

else: #否则

print(‘登陆失败‘) #判断不匹配输出

if的elif多次匹配条件判断,直到匹配成功结束

如:

uname = input(‘请输入用户名‘)

if uname == ‘liuming‘:

print(‘超级管理员‘)

elif uanme == ‘lisi‘:

print(‘sb‘)

elif uanme == ‘zhangsan‘:

print(‘admin‘)

else:

print(‘goodbay‘)

print(‘end‘)

2、while循环

格式:while 条件:

continue #立即跳出循环

break #跳出所有循环

如:

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

v = 1 #设置变量为1

while True: #while条件为正确时

if v == 7: #判断变量v是否等于7,

v += 1 # v = v + 1 每次循环v + 1

continue #如果条件匹配了7则跳入下一个循环,不输出7

print(v) #输出变量v

v += 1 #匹配了7后再加1

if v == 11: #判断变量v输出是否等于11

break #条件匹配跳出while循环

2、求1-100的和

a = 0 #设置变量a

b = 1 #设置变量b

while b < 101: #循环小于101内的数字

a += b #a = a + b

b += 1 #b = b + 1

print(a) #输出b的结果

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

a = 1 #设置变量a

while a < 101: #循环小于101内的数字

if a % 2 == 1: #判断a除2 是否等于1

print(a) #输出a

a += 1 #每次循环自动加一

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

a = 1 #设置变量a

while a <101: #循环小于101内的数字

if a % 2 == 0: #判断a除2是否等于0

print(a) #输出a

a += 1 #a + a + 1

5、求1-2+3-4+5...99的所有数的和(所有的奇数减所有的偶数)

a = 1 #

b = 0

while a < 100: #设置循环条件为当a大于100时终止循环

if a %2==1: #if判断a除以2等于1时输出奇数时

b = b + a #加1

elif a %2==0: #判断a除以2等于0时输出偶数时

b = b - a #减1

a +=1 #a = a + 1循环每次加1

print(b) #输出b加减的结果

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

import getpass

a = 0

user = input(‘请输入用户名:‘)

pwd =  getpass.getpass(‘请输入密码:‘)

while a <3:

if user ==‘liuming‘and pwd == ‘123‘:

print(‘欢迎登陆‘)

elif user == ‘lisi‘ and pwd == ‘123‘:

print(‘sb‘)

else:

print(‘滚蛋‘)

break

运算符

1、算数运算:

+ 两个对象相加

- 两个对象相减

* 两个对象相乘

/ 两个对象相除

% 取模-返回除法的余数

** 幂 返回x的y次幂

// 取整除 返回商的整数部分

2、比较运算

== 等于

!= 不等于

<> 不等于

> 大于

< 小于

>= 大于等于

<= 小于等于

3、赋值运算

= 赋值运算 如 c = a + b

+= 加法赋值

-= 减法赋值

*= 乘法赋值   如 a *= b 等同于 a = a * b

/= 除法赋值

%= 取模赋值

**= 幂赋值

//= 取整数赋值

4、逻辑运算

and 与

or  或

not 非

5、成员运算

in 如果在指定的序列中找到值返回true,否则为false

not in 如果在指定的序列中没有找到值返回true,否则为false

python数据类型

a. 整数 int

- 创建

a = 123

a = int(123)       #设置文本类型为数字

- 转换

age = "18"

new_age = int(age) #转换文本类型为数字

b. 布尔值

0或1

真或假

- 创建

a = True #真(是)

b = False #假(否)

- 转换

- 数字转换,只有0是False,其他True

- 字符串,  只有""是False,其他True

c. 字符串

- 创建

a = "alex"

a = str(‘alex‘) #把()里的东西转换为字符串

- 转换

age = 19

new_age = str(age)

- 字符串的拼接

name = ‘alex‘

gender = ‘女‘

new_str = name + gender

print(new_str)

- 字符串格式化

# 占位符,

# name = ‘我叫李杰,性别:%s,我今年%s岁,我在说谎!‘

# new_str = name %(‘男‘,19,)

# print(new_str)

name = ‘我叫李杰,性别:%s,我今年%s岁,我在说谎!‘ %(‘男‘,19,)

print(name)

- 判断子序列是否在其中

content = "Alex 前几天去泰国玩姑娘,一不小心染上了病,他的内心活动是,真该多来几个"

if "前几天去" in content:

print(‘包含敏感字符‘)

else:

print(content)

- 移除空白

val = " alex "

print(val)

# new_val = val.strip() # 左右

# new_val = val.lstrip()# 左边

# new_val = val.rstrip() # 右边

# print(new_val)

- 分割

user_info = "alex sb123 9"

# v = user_info.split(‘|‘)

# v = user_info.split(‘|‘,1)

# v = user_info.rsplit(‘ ‘,1)

# print(v)

- 长度(字符)

val = "李杰sb"

v = len(val)

print(v)

- 索引

val = "李杰sb"

v = val[0]

print(v)

val = input(‘>>>‘)

i = 0

while i < len(val):

print(val[i])

i += 1

- 切片

name = ‘我叫李杰,性别我今年岁,我在说谎!‘

print(name[0])

print(name[0:2])

print(name[5:9])

print(name[5:])

print(name[5:-2])

print(name[-2:])

d. 列表

创建:

a = [‘alex‘,‘狗‘,‘eric‘,123]

a = list([‘alex‘,‘狗‘,‘eric‘,123])

in判断:

if ‘al‘ in a:

pass

if ‘al‘ in a[0]:

pass

索引:

val = a[0]

长度:

val = len(a)

切片:

a = [‘alex‘,‘狗‘,‘eric‘,123]

v = a[0::2]

print(v)

追加:

a = [‘alex‘,‘狗‘,‘eric‘,123]

a.append(‘xxoo‘)

print(a)

插入:

a = [‘alex‘,‘狗‘,‘eric‘,123]

a.insert(0,‘牛‘)

print(a)

删除:

a = [‘alex‘,‘eric‘,‘狗‘,‘eric‘,123]

# a.remove(‘eric‘)

del a[0]

print(a)

更新:

a = [‘alex‘,‘eric‘,‘狗‘,‘eric‘,123]

a[1] = ‘阿斯顿发送到‘

print(a)

For循环:

a = [‘alex‘,‘eric‘,‘狗‘,‘eric‘,123]

for item in a:

print(item)

# break

# continue

e. 字典操作

- 创建

v = {

‘name‘: ‘alex‘,

‘password‘: ‘123123‘

}

# 常用操作

# 索引获取值

# n = v[‘name‘]

# print(n)

# 增加,无,增加;有,修改

# v[‘age‘] = 19

# print(v)

# 删除

# del v[‘name‘]

# print(v)

# 循环

# for item in v.keys():

#     print(item)

# for item in v.values():

#     print(item)

# for key,val in v.items():

#     print(key,val)

print(len(user_dict))

PS: 相互嵌套

user_dict = {

‘k1‘: ‘v1‘,

‘k2‘: {‘kk1‘:‘vv1‘,‘kk2‘:‘vv2‘},

‘k3‘: 123,

‘k4‘: [‘alex‘,‘eric‘,[‘a‘,‘b‘,‘c‘],‘李杰‘,{‘k11‘:‘vv1‘}],

}

user_dict[‘k4‘][2].append(‘123‘)

user_dict[‘k4‘][4][‘n‘] = ‘过啥龙‘

应用:

user_list = [

{‘name‘:‘alex‘,‘pwd‘:‘123123‘,‘times‘:1},

{‘name‘:‘eric‘,‘pwd‘:‘123123‘,‘times‘:1},

{‘name‘:‘tony‘,‘pwd‘:‘123123‘,‘times‘:1},

]

user = input(‘用户名:‘)

pwd = input(‘密码:‘)

for item in user_list:

if user == item[‘name‘] and pwd == item[‘pwd‘]:

print(‘登录成功‘)

break

时间: 2024-11-05 09:04:00

python one 1的相关文章

Python学习1-Python和Pycharm的下载与安装

本文主要介绍Python的下载安装和Python编辑器Pycharm的下载与安装. 一.Python的下载与安装 1.下载 到Python官网上下载Python的安装文件,进入网站后显示如下图: 网速访问慢的话可直接在这里下载:python-2.7.11.amd64 在Downloads中有对应的支持的平台,这里我们是在Windows平台下运行,所以点击Windows,出现如下: 在这里显示了Python更新的所有版本,其中最上面两行分别是Python2.X和Python3.X对应的最后更新版本

Python——深入理解urllib、urllib2及requests(requests不建议使用?)

深入理解urllib.urllib2及requests            python Python 是一种面向对象.解释型计算机程序设计语言,由Guido van Rossum于1989年底发明,第一个公开发行版发行于1991年,Python 源代码同样遵循 GPL(GNU General Public License)协议[1] .Python语法简洁而清晰,具有丰富和强大的类库. urllib and urllib2 区别 urllib和urllib2模块都做与请求URL相关的操作,但

python学习_day26_面向对象之封装

1.私有属性 (1)动态属性 在python中用双下划线开头的方式将属性隐藏起来.类中所有双下划线开头的名称,如__x都会自动变形成:_类名__x的形式.这种自动变形的特点是: a.类中定义的__x只能在内部使用,如self.__x,引用的就是变形的结果.b.这种变形其实正是针对外部的变形,在外部是无法通过__x这个名字访问到的.c.在子类定义的__x不会覆盖在父类定义的__x,因为子类中变形成了:_子类名__x,而父类中变形成了:_父类名__x,即双下滑线开头的属性在继承给子类时,子类是无法覆

python面向对象知识点疏理

面向对象技术简介 类: 用来描述具有相同的属性和方法的对象的集合.它定义了该集合中每个对象所共有的属性和方法.对象是类的实例.class 类变量:类变量在整个实例化的对象中是公用的.类变量定义在类中且在函数体之外.类变量通常不作为实例变量使用. 数据成员:类变量或者实例变量用于处理类及其实例对象的相关的数据. 方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖,也称为方法的重写. 实例变量:定义在方法中的变量,只作用于当前实例的类. 继承:即一个派生类(de

python实现网页登录时的rsa加密流程

对某些网站的登录包进行抓包时发现,客户端对用户名进行了加密,然后传给服务器进行校验. 使用chrome调试功能断点调试,发现网站用javascript对用户名做了rsa加密. 为了实现网站的自动登录,需要模拟这个加密过程. 网上搜了下关于rsa加密的最简明的解释: rsa加密是非对称加密算法,该算法基于一个十分简单的数论事实:将两个大素数相乘十分容易,但那时想要对其乘积进行因式分解却极其困难,因此可以将乘积公开作为加密密钥,即公钥,而两个大素数组合成私钥.公钥是可发布的供任何人使用,私钥则为自己

Python中编码的详细讲解

看这篇文章前,你应该已经知道了为什么有编码,以及编码的种类情况 ASCII 占1个字节,只支持英文 GB2312 占2个字节,支持6700+汉字 GBK GB2312的升级版,支持21000+汉字 Shift-JIS 日本字符 ks_c_5601-1987 韩国编码 TIS-620 泰国编码 由于每个国家都有自己的字符,所以其对应关系也涵盖了自己国家的字符,但是以上编码都存在局限性,即:仅涵盖本国字符,无其他国家字符的对应关系.应运而生出现了万国码,他涵盖了全球所有的文字和二进制的对应关系, U

Python练习(一)

Python练习(一): 给一个不超过5位的正整数,判断其有几位,依次打印出个位.十位.百位.千位.万位的数字: num = int(input('please enter a number: '))   lst = [] for i in str(num):      lst.append(i) lenlst = len(lst) if num >= 1000:      if num >= 10000:          print('too big')     else:        

菜鸟学python之对象类型及运算

Python 中的变量不需要声明.每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建. 在 Python 中,变量就是变量,它没有类型,我们所说的"类型"是变量所指的内存中对象的类型. 等号(=)用来给变量赋值. 1 变量赋值 1.1 单个变量赋值 >>> name="python" >>> print(name) python 1.2 多个变量赋值 >>> name=names="python&

开始我的Python爬虫学习之路

因为工作需要经常收集一些数据,我就想通过学爬虫来实现自动化完成比较重复的任务. 目前我Python的状况,跟着敲了几个教程,也算是懂点基础,具体比较深入的知识,是打算从做项目中慢慢去了解学习. 我是觉得如果一开始就钻细节的话,是很容易受到打击而放弃的,做点小项目让自己获得点成就感路才更容易更有信心走下去. 反正遇到不懂的就多查多问就对了. 知乎上看了很多关于入门Python爬虫的问答,给自己总结出了大概的学习方向. 基础: HTML&CSS,JOSN,HTTP协议(这些要了解,不太需要精通) R

解决:Elipse配置Jython Interpreters时报错Error: Python stdlib source files not found

今天学习lynnLi的博客monkeyrunner之eclipse中运行monkeyrunner脚本之环境搭建(四)时,遇到了一个问题,即: lynnLi给出的解决办法是:将Python下的Lib拷贝到sdk中jython-standalone-2.5.3.jar所在目录tools\lib,再次New一个Jython,添加jython-standalone-2.5.3.jar路径即可 但是这样尝试,又报错了: 后来借鉴了这篇文章的做法,成功配置Jython Interpreters: 将\sdk