王二学习python的笔记以及记录,如有雷同,那也没事,欢迎交流,wx:wyb199594

学习内容

1.文件处理
1.打开文件
open(‘路径’,‘打开方式’)
打开方式 r w a r+ w+ a+
ps: r+ 打开文件直接写,和读完再写不一样,光标会变
1.操作文件
a.读
read 一次性
readline 一行一行, 不知道在哪里结束
#视频 图片 rb打开 按照字节读
readlines 一次性读
for 循环-----最好用
b.写
write
c.光标 -----文件指针
seek 指定位置
tell 获取位置
truncate 截取文件
d.关闭
close
e.文件无法被直接修改,可以读—写—删除—重命名—— 完成
2.函数
a.没有返回值 (None)
1.不写return
2.只写return :return后面的函数体不执行
3.return None
b.返回一个值
任何数据类型,
c.返回多个值
return a,b,... 多个返回值需要多个变量分别接受
用一个变量接受,则以元祖形式存在
a.参数
实际参数,形式参数
参数设置
1.无参数
2.一个参数
3.多个参数, 位置参数,
实际参数角度:按照位置传,或者关键字传
形式参数角度:必须传,数量相同
4.定义函数时:
位置参数
默认参数,关键字参数
动态参数,*args位置传参 **kwargs 接受任意多个关键字参数
重要:顺序:位置参数+动态参数*args+默认参数+**kwargs
动态参数:
def func(*args): #组合序列 **kwargs 同样原理,打散字典
print(args)
func(1,2,3,4,5)
l = [1,2,3,4,5]
func(*l) #打散序列
a.函数注释
'''
函数功能
参数意义要求
返回值
'''

代码区

1.考试题

1.数字字母下划线任意组合,数字不能大头
2.1字节=8位
3.3字节 24位,2字节 16位
4. append 5.int 0 str'' list[] tuple{} dic{}
6.python2 复杂,重复代码多;编码方式不同;
7. l3 = li[0:-1:2]
l4 = li[1:6:2]
l5 = li[-1:6:-1]
l6 = li[5:0:-2]
8a. lis[0][1][2]['k1'][0] = 'TT'
lis[0][1][2]['k1'][0] = lis[0][1][2]['k1'][0].upper()
lis[0][1][2]['k1'][1] = ''
lis[0][1][2]['k1'] = ['TT', 3, 101]
8b. dic['k2'].append('')
dic['k2'].insert(0, 'a')
dic[(1, 2, 3, 4, 5)].setdefault('k4', 'v4')
dic[(1, 2, 3, 4, 5)].setdefault((1, 2, 3), 'ok')
dic[(1, 2, 3, 4, 5)]['k3'][2] = 'qq'
9. int--str 直接转换
int--bool 0-False 其余True
str--bool 空''- False 其余为True
str--list split
10. s = li[0] + li[1] + li[2]
print(''.join(li))
print('*'.join(li))
print(s.split('l', 1))
11. count = 0
sum = 0
while count < 99:
count += 1
if count %2 == 0:
sum = sum - count
else:
sum = sum + count
print(sum)
sum1 = 0
for i in range(100):
if i % 2 == 0:
sum1 = sum1 - i
else:
sum1 = sum1 + i
print(sum1)
12.for i in range(100, -1, -1):
print(i)
13.s = 'a1a2a3a4a5a6'
count = 0
x = 0
for i in s:
if i.isdigit() and count % 2 == 1:
x += 1
count += 1
print(x)
14.li = [11, 22, 33, 44, 55, 77, 88, 99]
result = {}
for row in li:
result.setdefault('k1', [])
result.setdefault('k2', [])
if row < 66:
result['k1'].append(row)
else:
result['k2'].append(row)
print(result)
14b.li = [11, 22, 33, 44, 55, 77, 88, 99]
result = {}
for row in li:
if row > 66:
if 'key1' not in result.keys():
result['key1'] = []
result['key1'].append(row)
else:
if 'key2' not in result.keys():
result['key2'] = []
result['key2'].append(row)
print(result)
15.li = ['taibai', 'alexC', 'AbC', 'egon', 'Ritian', 'Wusir', ' aqc']
res = []
for i in range(len(li)):
li[i] = li[i].strip()
if li[i][-1] == 'c' and li[i].capitalize()[0] == 'A':
res.append(li[i])
print(li)
print(res)
16.count = '5+8+7 +1'
li = count.split('+')
dic = {'最终计算结果': None}
sum = 0
for i in li:
sum = sum + int(i)
dic['最终计算结果'] = sum
print(dic)

2.‘’修改‘’文件

with open('log', encoding='utf-8') as f, open('log.bak','w',encoding='utf-8') as f2:
for line in f:
if '小刘' in line:
line = line.replace('小刘', '')
print(line)
f2.write(line)
import os
os.remove('log')
os.rename('log.bak', 'log')

python之路——9的更多相关文章

  1. Python之路【第一篇】python基础

    一.python开发 1.开发: 1)高级语言:python .Java .PHP. C#  Go ruby  c++  ===>字节码 2)低级语言:c .汇编 2.语言之间的对比: 1)py ...

  2. Python之路

    Python学习之路 第一天   Python之路,Day1 - Python基础1介绍.基本语法.流程控制              第一天作业第二天   Python之路,Day2 - Pytho ...

  3. python之路 目录

    目录 python python_基础总结1 python由来 字符编码 注释 pyc文件 python变量 导入模块 获取用户输入 流程控制if while python 基础2 编码转换 pych ...

  4. Python之路【第十九篇】:爬虫

    Python之路[第十九篇]:爬虫   网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本.另外一些不常使用 ...

  5. Python之路【第十八篇】:Web框架们

    Python之路[第十八篇]:Web框架们   Python的WEB框架 Bottle Bottle是一个快速.简洁.轻量级的基于WSIG的微型Web框架,此框架只由一个 .py 文件,除了Pytho ...

  6. Python之路【第十七篇】:Django【进阶篇 】

    Python之路[第十七篇]:Django[进阶篇 ]   Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...

  7. Python之路【第十六篇】:Django【基础篇】

    Python之路[第十六篇]:Django[基础篇]   Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...

  8. Python之路【第十五篇】:Web框架

    Python之路[第十五篇]:Web框架   Web框架本质 众所周知,对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端. 1 2 3 4 5 6 ...

  9. Python之路【第九篇】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

    Python之路[第九篇]:Python操作 RabbitMQ.Redis.Memcache.SQLAlchemy   Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用 ...

  10. Python之路【第八篇】:堡垒机实例以及数据库操作

    Python之路[第八篇]:堡垒机实例以及数据库操作   堡垒机前戏 开发堡垒机之前,先来学习Python的paramiko模块,该模块机遇SSH用于连接远程服务器并执行相关操作 SSHClient ...

随机推荐

  1. h5 中软键盘弹出后,点击退出键盘,页面无法恢复

    input 绑定blur事件,设置 window.scroll(0,0);

  2. Charles抓包基本用法

    Charles抓包 浏览器发送和接受的所有请求都可以抓到 1.可以定位问题(如果看不出来是服务端问题还是前端问题) 2.可以设置弱网模式 清空请求按钮如图: 抓包: 1 打开charles,在浏览器中 ...

  3. mpvue 解析

    前言 mpvue是一款使用Vue.js开发微信小程序的前端框架. 总结   生命周期的理解 文档 一次前后端实践 使用此框架,开发者将得到完整的 Vue.js 开发体验,同时为H5和小程序提供了代码复 ...

  4. mysql-5.7.23-winx64.zip安装教程

    请参考这篇文章:https://www.jianshu.com/p/94647c0c98c4

  5. 仿XP系统的任务栏菜单

    using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using Sy ...

  6. js 查找当前元素/this

    function findTabTitle(pageId) { var $ele = null; $(".page-tabs-content").find("a.menu ...

  7. VirtualBox安装CENTOS7.3常见问题

    1 DHCP 问题无法上网解决 :sudo dhclient 2 安装宝塔面板:yum install -y wget && wget -O install.sh http://dow ...

  8. B-trees

    B-trees are balanced search trees designed to work well on disks or other direct accesssecondary sto ...

  9. Linux 堆溢出原理分析

    堆溢出与堆的内存布局有关,要搞明白堆溢出,首先要清楚的是malloc()分配的堆内存布局是什么样子,free()操作后又变成什么样子. 解决第一个问题:通过malloc()分配的堆内存,如何布局? 上 ...

  10. Scrapy、Scrapy-redis组件

    目录 Scrapy 一.安装 二.基本使用 1. 基本命令 2.项目结构以及爬虫应用简介 3. 小试牛刀 4. 选择器 5. 格式化处理 6.中间件 7. 自定制命令 8. 自定义扩展 9. 避免重复 ...