python自动化day1
一、变量
变量定义的规则:
- 变量名只能是 字母、数字或下划线的任意组合
- 变量名的第一个字符不能是数字
- 以下关键字不能声明为变量名
['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']
推荐方式#下划线 age_of_oldboy = 56 number_of_students = 80
id 位置==>内存
type ====>类型
value ==>值
二、程序交互 input
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# 将用户输入的内容赋值给 name 变量
name = input("请输入用户名:")
# 打印输入的内容
print(name)
三、数据类型
int ====> 整型数字
a = 10
str ====> 字符串类型
只要是引号里的,都是字符串类型
name = "zbb" print(name)
字符串分割
>>> msg = 'zbb|zxx'
>>> msg.split('|')
['zbb', 'zxx']
>>>
列表
可以存放多个值,每个值都可以是任意类型
d =['a','12','c'] print (d) ['a', '12', 'c']
字典
采用key:velue的方式储存值,可以存放多个值
每个value可以是任意数据类型
但key必须是不可变数据类型
dic = {'name':'zbb','age':'12'}
dic['name']
'zbb'
dic['name'] = 'zb'
dic
{'name': 'zb', 'age': '12'}
可变类型(不可hash类型)
字典与列表属于可变类型
id 不变 ===== type不变========值变了
不可变数据类型
数字和字符串属于不可变类型
四、布尔类型
布尔类型很简单,就两个值 ,一个True(真),一个False(假)
>>> a=3 >>> b=5 >>> >>> a > b #不成立就是False,即假 False >>> >>> a < b #成立就是True, 即真 True
五、格式化输出
%s就是代表字符串占位符(也可以接受数字),除此之外,还有%d,是数字占位符
%%
第一个%是对第二个%的转译,告诉Python解释器这只是一个单纯的%,而不是占位符。
msg='''
------------ info of %s -----------
Name : %s
Age : %s
job : %s
Hobbie: %s
------------- end -----------------
''' %('zbb','zbb','18','运维','玩')
print(msg )
------------ info of zbb ----------- Name : zbb Age : 18 job : 运维 Hobbie: 玩 ------------- end -----------------
改变字符串类型
age = input('your age :')
x = int(age)
print(x,type(x))
#简化
x = int(input('your age :'))
print(x,type(x))
六、运算符
计算机可以进行的运算有很多种,可不只加减乘除这么简单,运算按种类可分为算数运算、比较运算、逻辑运算、赋值运算、成员运算、身份运算、位运算,今天我们暂只学习算数运算、比较运算、逻辑运算、赋值运算、成员运算
算数运算
以下假设变量:a=10,b=20

比较运算
以下假设变量:a=10,b=20

赋值运算
以下假设变量:a=10,b=20

逻辑运算

针对逻辑运算的进一步研究:
1,在没有()的情况下not 优先级高于 and,and优先级高于or,即优先级关系为( )>not>and>or,同一优先级从左往右计算。
Python运算符优先级
以下表格列出了从最高到最低优先级的所有运算符:
| 运算符 | 描述 |
|---|---|
| ** | 指数 (最高优先级) |
| ~ + - | 按位翻转, 一元加号和减号 (最后两个的方法名为 +@ 和 -@) |
| * / % // | 乘,除,取模和取整除 |
| + - | 加法减法 |
| >> << | 右移,左移运算符 |
| & | 位 'AND' |
| ^ | | 位运算符 |
| <= < > >= | 比较运算符 |
| <> == != | 等于运算符 |
| = %= /= //= -= += *= **= | 赋值运算符 |
| is is not | 身份运算符 |
| in not in | 成员运算符 |
| not and or | 逻辑运算符 |
七、流程控制之if...else
假如把写程序比做走路,那我们到现在为止,一直走的都是直路,还没遇到过分叉口,想象现实中,你遇到了分叉口,然后你决定往哪拐必然是有所动机的。你要判断那条岔路是你真正要走的路,如果我们想让程序也能处理这样的判断怎么办? 很简单,只需要在程序里预设一些条件判断语句,满足哪个条件,就走哪条岔路。这个过程就叫流程控制。
if...else 语句
单分支
if 条件:
满足条件后要执行的代码
双分支
if 条件:
满足条件执行代码
else:
if条件不满足就走这段
age = 10
if age > 40:
print('lnb ')
else:
print("xnb")
多分支+判断
age = 50
age_inp = int(input('请输入我的年龄'))
if age_inp > age:
print('too big')
elif age_inp < age:
print('too small')
else:
print('you get it ')
八、流程控制之while循环
count = 0
while count <= 100:
if count >3 and count <= 96:
count +=1
continue# break #跳出本层循环 continue 退出本次循环
print(count)
count+=1

while与if配合玩游戏三次机会
age = 50
count = 1
while count <=3:
age_inp = int(input('请输入我的年龄'))
if age_inp > age:
print('too big')
count+=1
elif age_inp < age:
print('too small')
count+=1
else:
print('you get it ')
break
写一个输入q 退出的程序
while True:
cmd = input('>>: ')
if cmd == 'q':
break
请输入用户名+密码,错误 超过三次退出
count =
while True:
:
print("输入次数过多!")
break
user=input('user: ')
password=input('password: ')
":
print( '输入正确!')
break
else:
print('输入错误!')
count+=
请输入用户名+密码,错误 超过三次退出 。成功之后,执行命令,按q退出
count =0
while True:
if count >2:
print("输入次数过多!")
break
user=input('user: ')
password=input('password: ')
":
print( '输入正确!')
while True:
cmd = input('>>: ')
if cmd == 'q':
break
print('exec %s' %cmd)
else:
print('输入错误!')
count+=1
优化 上面代码
count =0
tag = True
while tag:
if count >2:
print("输入次数过多!")
break
user=input('user: ')
password=input('password: ')
":
print( '输入正确!')
while tag:
cmd = input('>>: ')
if cmd == 'q':
tag = False
continue
print('exec %s' %cmd)
else:
print('输入错误!')
count+=1
while与else连用
count = 1
while count <=5:
#if count ==2:
#break
print(count)
count+=1
else:
#while没有被break打断的时候可以执行else的子代码
print('========>>>')
作业

count =1
age = 50
while True:
if count > 3:
jx = input('是否要继续?')
if jx == 'y':
count = 1
continue
elif jx == 'n':
break
age = int(input('请输入我的年龄'))
if age == 50:
print('猜对了')
break
else:
print('猜错了')
count+=1
基础需求:
- 让用户输入用户名密码
- 认证成功后显示欢迎信息
- 输错三次后退出程序
升级需求:
- 可以支持多个用户登录 (提示,通过列表存多个账户信息)
- 用户3次认证失败后,退出程序,再次启动程序尝试登录时,还是锁定状态(提示:需把用户锁定的状态存到文件里)
python自动化day1的更多相关文章
- Day1 老男孩python自动化运维课程学习笔记
2017年1月7日老男孩python自动化运维课程正式开课 第一天学习内容: 上午 1.python语言的基本介绍 python语言是一门解释型的语言,与1989年的圣诞节期间,吉多·范罗苏姆为了在阿 ...
- python自动化运维学习第一天--day1
学习python自动化运维第一天自己总结的作业 所使用到知识:json模块,用于数据转化sys.exit 用于中断循环退出程序字符串格式化.format字典.文件打开读写with open(file, ...
- python自动化运维之路~DAY5
python自动化运维之路~DAY5 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.模块的分类 模块,用一砣代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数 ...
- flow.ci + Github + Slack 一步步搭建 Python 自动化持续集成
理想的程序员必须懒惰,永远追随自动化法则.Automating shapes smarter future. 在一个 Python 项目的开发过程中可能会做的事情:编译.手动或自动化测试.部署环境配置 ...
- Selenium2+python自动化23-富文本(自动发帖)
前言 富文本编辑框是做web自动化最常见的场景,有很多小伙伴遇到了不知道无从下手,本篇以博客园的编辑器为例,解决如何定位富文本,输入文本内容 一.加载配置 1.打开博客园写随笔,首先需要登录,这里为了 ...
- Selenium2+python自动化24-js处理富文本(带iframe)
前言 上一篇Selenium2+python自动化23-富文本(自动发帖)解决了富文本上iframe问题,其实没什么特别之处,主要是iframe的切换,本篇讲解通过js的方法处理富文本上iframe的 ...
- Selenium2+python自动化7-xpath定位
前言 在上一篇简单的介绍了用工具查看目标元素的xpath地址,工具查看比较死板,不够灵活,有时候直接复制粘贴会定位不到.这个时候就需要自己手动的去写xpath了,这一篇详细讲解xpath的一些语法. ...
- Selenium2+python自动化13-Alert
不是所有的弹出框都叫alert,在使用alert方法前,先要识别出它到底是不是alert.先认清楚alert长什么样子,下次碰到了,就可以用对应方法解决.alert\confirm\prompt弹出框 ...
- 【python自动化第十一篇】
[python自动化第十一篇:] 课程简介 gevent协程 select/poll/epoll/异步IO/事件驱动 RabbitMQ队列 上节课回顾 进程: 进程的诞生时为了处理多任务,资源的隔离, ...
随机推荐
- thread常用方法
- wait命令
wait命令用来等待指令的指令,直到其执行完毕后返回终端.该指令常用于shell脚本编程中,待指定的指令执行完成后,才会继续执行后面的任务.该指令等待作业时,在作业标识号前必须添加备份号"% ...
- Codeforces 1077(F1+F2) DP 单调队列
题意:给你一个n个元素的数组,从中选取x个元素,并且要保证任意的m个位置中必须至少有一个元素被选中,问选中元素的和最大可以是多少? F1 n,m,x到200 F2 n,m,x到5000. 思路1:设d ...
- No bean class specified on bean definition 解决方案
调试Spring项目出现No bean class specified on bean definition异常 但是控制台并没有给出其他相关信息了 这个时候可以在AbstractBeanDefini ...
- ubuntu下使用PIL中的show函数,无法显示图片的问题
问题描述:ubuntu14.04系统,python2.7(version),正在学习python中, from PIL import Image im = Image.open('1.jpg') im ...
- ZROI2018提高day9t1
传送门 分析 我们首先想到的自然是根据大小关系建图,在这之后我们跑一遍拓扑排序 但是由于l和r的限制关系我们需要对传统的拓扑排序做一些改变 我们考虑将所有入度为0且现在的拓扑序号已经大于等于l的点放入 ...
- 51NOD1052 最大M字段和
传送门 分析 一眼看去我们自然会想到dp[i][j][k]表示区间[i,j]中选k个子段的最大值.然后我们考虑降去一维.我们设dp[i][j]表示考虑了前i个数,在选了a[i]的情况下共有j个子段的最 ...
- Luogu 2375 [NOI2014]动物园
字胡串什么的一直不太会,感觉这题…还蛮本质的 考虑暴力求解:num[i]相当于从一直跳nxt,如果nxt[j] * 2 <= i 那么就累加答案 其实这是一个树的结构,也就是说跳到一个结点满足条 ...
- ConcurrentHashMap的putIfAbsent
这个方法在key不存在的时候加入一个值,如果key存在就不放入,等价: if (!map.containsKey(key)) return map.put(key, value); else retu ...
- Spring第五篇
在Spring第四篇中 我们主要介绍了set get的注入方式 在Spring第五篇中 我们主要介绍使用注解配置Spring 主要分为两个步骤 1 导包的同时引入新得约束 导包如下 1.1 重写注解代 ...