Python第二天

Python中的循环

先介绍for循环

格式:

for 临时变量 in 可迭代对象:

循环体

 name = 'neusoft'
for x in name:
     print(x)
     if x =='s':
         print('666')
  • 这个x是什么?
    x是临时变量,不用提前声明 Python自动为你创建
  • 循环次数哪里去了?
    range(起始位置,终止位置,步长)可以写循环次数
  1. 起始位置省略,默认为0,步长省略,默认为1,范围是左闭右开
    给女朋友道歉100次
 for i in range (1,101,2):
     print('对不起!!!我错了!!!!,这是我',i,'次向您道歉')

常用数据类型

数字、列表、字符串、字典、元组、集合

  1. 创建一个列表
 heroList = ["鲁班七号","安琪拉","李白",'后羿',100,10.1]
 print(heroList)

总结:列表使用[]进行创建

  • 为什么要使用列表?
    列表可以将我们需要的很多元素封装到一个容器中。
  • 列表的相关操作:
    1.访问列表中元素 列表名[索引]
 print("英雄为:",heroList[0],heroList[3])

2.添加元素 append是在列表的末尾进行添加元素

 heroList.append('鲁班大师')
 print("添加后的列表",heroList)
  1. 修改
 heroList[4]='貂蝉'
 print("修改后的列表",heroList)

4.删除

 del heroList[5]
 print("删除后的列表",heroList)

生成一个[0,1,2,......20]的列表,可以使用循环来创建

  • 创建一个空列表
list1 = []  #使用循环不停的append
for i in range(21):
     list1.append(i)
     print(list1)
  • 遍历herolist
 for hero in heroList:
     print(hero)

len()可以检测对象的元素个数

for i in range (len(heroList)):
 print(heroList[i])
     if heroList[i]=='后羿':
         print('恭喜你选中了隐藏英雄')
     else:
         print('不是隐藏英雄')

Python制作进度条

安装 tqdm库

  • pip install 库的名称
  • 导入 tqdm
from tqdm import tqdm
import time
mylist = []
for i in range(20):
    mylist.append(i)
    print(mylist)
  • 遍历mylist
for x in tqdm(mylist):
    time.sleep(0.5)

字符串

  • 表示 ‘’ “ ” 都可以
 name = ' K"o"be '
 print(name)

访问

print(name[3])

修改

 name[1] = "x"
 print(name)
 name = "kobe"
 print(name)

常用操作

 price = '¥9.9'

字符串的替换

 price = price.replace("¥",'')
 print(price)

价格涨价10倍

new_price = float(price)*10
print(new_price)

写一个价值一亿的AI代码

 while True:
     seg = input('')
     seg = seg.replace('吗?','!')
     print(seg)

strip 去空格

 name = '   neuedu   '
 print(len(name))
 name = name.strip()
 print(len(name))

join 将列表变成字符串

li = ['you ','are ','handsome']
disk_path=['C:','Users','DELL','Desktop','大三上学期']
path = '\\'.join(disk_path)
print(path)
li=''.join(li)
print(li)

元组

  • tuple()
  • list()
  • int()
  • str()
  1. 创建
    元组和列表很相似,只不过不能修改
a = (1,'1',3)
 print(a)
 print(type(a))
  1. 访问
 print(a[2])
 a[2] = 6  错误

元组的用处:

1、写保护,安全,Python内置函数返回的类型都是元组
2、相对于列表来讲,元组更节省空间,效率更高

掌握
1、拥有一个元素的元组

 b = (100,)
 print(type(b))

我们经常用的组合组合方式是:

list2=[('a',22),('b',33),('c',99)]

字典

创建字典 key -value

info = {'name':'费星浩','age':20,'gender':'male'}
 print(type(info))

访问字典 通过建访问值

print(info['name'])

访问不存在的建

print(info['add'])

当不存在这个建的时候,可以返回默认设置的值; 有这个建就正常返回

print(info.get('addr','抚顺市'))

修改

 info['age'] = 3
 print(info)

增加

当字典中不存在这个建,就会添加
 info['addr'] = '鞍山市'
 print(info)

删除

 del info['age']
 print(info)
###遍历

for k,v in info.items():
print(k,'------->',v)

获取所有建

print(list(info.keys()))
#获取所有值
print(list(info.values()))

爬虫

1.获取到网页的源代码 requests

安装requests

  pip install requests
  import requests
# 获取指定域名的源代码
response = requests.get('https://www.baidu.com')
# 响应状态码 200 ok   404 not found
print(response.status_code)
# 响应的编码方式
# 设置编码方式
response.encoding = 'utf-8'
print(response.status_code)
print(response.encoding)
# # 获取 string类型的响应
html_data = response.text
print(html_data)
# # 将爬取的文件写成本地 html
with open('index.html','w',encoding='utf-8') as f:
    f.write(html_data)
# 文件路径,读写模式,编码方式

# 图片爬取
# 图片地址
url = 'http://b-ssl.duitang.com/uploads/item/201805/09/20180509003136_epwlq.jpg'
response2 = requests.get(url)
#获取byte类型的响应
img_data = response2.content
with open('bts.jpg','wb') as f:
    if response2.status_code == 200:
        f.write(img_data)

你可能感兴趣的:(Python第二天)