python自动化之读写
#############################################################################
#############在Windows上:路径使用倒斜杠作为文件夹之间的分隔符###############
#############在OS X和Linux上:使用正斜杠作为文件夹之间的分隔符###############
import os
os.path.join('usr','bin','spam') ########根据不同系统得到不同路径#########
myFiles=['accounts.txt','detailes.csv','invite.docx']
for filename in myFiles:
print(os.path.join('C:\\Users\\asweigart',filename))
##############################当前工作目录###################################
os.getcwd()
##############################改变工作目录###################################
os.chdir('C:\\Windows\\System32')
#############################创建新文件夹####################################
os.makedirs('C:\\delicious\\walnut\\waffles') ####将创建所有必要的中间文件夹
####################处理绝对路径和相对路径###################################
os.path.abspath('.') ####返回当前路径下的绝对路径
os.path.isabs(path) ####如果参数是一个绝对路径,就返回True,如果参数是一个
####相对路径,就返回False
os.path.relpath(path,start) ####将返回从start路径到path的相对路径的字符串
path='C:\\Windows\\System32\\calc.exe'
os.path.basename(path) ####文件名
os.path.dirname(path) ####对应整个文件夹名
calcFilePath='C:\\Windows\\System32\\calc.exe'
os.path.split(calcFilePath) ####得出文件名+对应整个文件夹名
os.path.getsize('C:\\Windows\\System32\\calc.exe')
##########调用os.path.getsize(path) 将返回path参数中文件的字节数
os.listdir('C:\\Windows\\System32')
##########调用os.listdir(path) 将返回文件名字符串的列表
##########该目录下所有文件的总字节数
totalsize=0
for filename in os.listdir('C:\\Windows\\System32'):
totalsize=totalsize+os.path.getsize(os.path.join('C:\\Windows\\System32'+filename))
print(totalsize)
##########检查路径有效性
os.path.exists('C:\\Windows') ####所指的文件或文件夹是否存在
os.path.isdir('C:\\Windows\\System32') ####所指的文件夹是否存在
os.path.isfile('C:\\Windows\\System32') ####所指的文件是否存在
#########文件读写过程
helloFile=open('C:\\Users\\your_home_folder\\hello.txt') ####调用open()将返回一个File对象,保存到helloFile中
helloContent=helloFile.read() ####File对象的read()方法,将整个文件的内容读取为一个字符串值
helloFile.readlines() #####从该文件取得一个字符串的列表,列表中的每个字符串是文件中的每一行
########写入文件
#####写模式:从头开始,将'w'作为第二个参数传递给open()
#####写模式:添加,将'a'作为第二个参数传递给open()
#####打开后需要File.close()
#####write()方法不同于print()(能自动添加换行符),需要手动添加
##########################漂亮打印:将列表或字典中的内容"漂亮打印"到屏幕上
import pprint
message='It was a braight cold day in April, and the clocks were striking thirteen.'
count={}
for character in message:
count.setdefault(character,0)
count[character]=count[character]+1
pprint.pprint(count)
###########pprint.pformat()将返回同样的文本字符串,不仅易于阅读,同时也是语法上正确的python代码
import pprint
cats=[{'name':'Zophie','desc':'chubby'},{'name':'Pooka','desc':'fluffy'}]
pprint.pformat(cats)
fileObj=open('mycats.py','w')
fileObj.write('cats='+pprint.pformat(cats)+'\n')
fileObj.close()
#####用shelve模块保存变量
import shelve
shelfFile=shelve.open('mydata')
cats=['Zophie','Pooka','Simon']
shelfFile['cats']=cats
shelfFile.close()
####就像字典一样,shelf值有keys()和values()方法,返回shelf中键和值的类似列表的值
shelfFile=shelve.open('mydata')
list(shelfFile.keys())
list(shelfFile.valus())
shelfFile.close()
############疯狂填词
import os
import re
lib=open(r'C:\Python27\Lib\site-packages\xy\libs.txt')
libstr=lib.read()
sillyregex=re.compile(r'ADJECTIVE')
libstr=sillyregex.sub('silly',libstr)
chandelierregex=re.compile(r'NOUN')
libstr=chandelierregex.sub('chandelier',libstr)
print libstr
fileObj=open(r'C:\Python27\Lib\site-packages\xy\file.txt','w')
fileObj.write(libstr)
fileObj.close()
####
######################################################################################################
# -*- coding: utf-8 -*-
"""
Created on Thu May 04 11:12:41 2017
@author: Sl
"""
"""
##########################################################需制作###################################################################
#1、35份不同的测试试卷
#2、每份试卷创建25个多重选择题,次序随机
#3、每个问题提供一个正确答案和3个随机的错误答案,次序随机
#4、将测试试卷写到35个文本中
#5、将答案写到35个文本中
###################################################################################################################################
"""
import random
capitals={'Alabama':'Montgomery','Alaska':'Juneau','Arizona':'Phoenix','Arkansas':'Little Rock','California':'Sacramento',
'Colorado':'Denver','Connecticut':'Hartford','Delaware':'Dover','Florida':'Tallahassee','Georgia':'Atlanta','Hawaii':'Honolulu',
'Idaho':'Boise','Illinois':'Springfield','Indiana':'Indianapolis','Iowa':'Des Moines','Kansas':'Topela','Kentucky':'Frankfort',
'Louisiana':'Baton Rouge','Maine':'Augusta','Maryland':'Annapolis','Massachusetts':'Boston','Michigan':'Lansing','Minnesota':'Saint Paul',
'Mississippi':'Jackson','Missouri':'Jefferson City'}
for quizNum in range(35):
quizFile=open(r'C:\Python27\Lib\site-packages\xy\capitals\capitalsquiz%s'%(quizNum+1),'w')
answerFile=open(r'C:\Python27\Lib\site-packages\xy\capitals\capitalsquiz_answer%s'%(quizNum+1),'w')
quizFile.write('Name:\n\nDate:\n\nperiod:\n\n')
quizFile.write(' '*20+'State Capitals Quiz (Form %s)'%(quizNum+1))
quizFile.write('\n\n')
states=list(capitals.keys())
random.shuffle(states)
for questonNum in range(25):
correctAnswer=capitals[states[questonNum]]
wrongAnswer=list(capitals.values())
del wrongAnswer[wrongAnswer.index(correctAnswer)]
wrongAnswer=random.sample(wrongAnswer,3)
answerOptions=wrongAnswer+[correctAnswer]
random.shuffle(answerOptions)
quizFile.write('%s. What is the capitals of %s?\n'% (questonNum+1,states[questonNum]))
quizFile.write('\n')
for i in range(4):
quizFile.write('%s. %s\n'%('ABCD'[i],answerOptions[i]))
quizFile.write('\n')
answerFile.write('%s. %s\n'%(questonNum+1,'ABCD'[answerOptions.index(correctAnswer)]))
quizFile.close()
answerFile.close()
######################################################################################################
'''
@pyw.exe C:\\Python34\mcb.pyw %*
##########多重剪贴板
#注释和shelf设置
'''
import shelve,pyperclip,sys
mcbshelf=shelve.open('mcb')
#TODO:save clipboard content
if len(sys.argv)==3 and sys.argv[1].lower()=='save':
mcbshelf[sys.argv[2]]==pyperclip.paste()
elif len(sys.argv)==2:
#TODO:List Keywords and load content
if sys.argv[1].lower()=='list':
pyperclip.copy(str(list(mcbshelf.keys())))
elif sys.argv[1] in mcbshelf:
pyperclip.copy(mcbshelf[sys.argv[1]])
mcbshelf.close()
python自动化之读写的更多相关文章
- python自动化运维学习第一天--day1
学习python自动化运维第一天自己总结的作业 所使用到知识:json模块,用于数据转化sys.exit 用于中断循环退出程序字符串格式化.format字典.文件打开读写with open(file, ...
- python自动化开发学习 I/O多路复用
python自动化开发学习 I/O多路复用 一. 简介 socketserver在内部是由I/O多路复用,多线程和多进程,实现了并发通信.IO多路复用的系统消耗很小. IO多路复用底层就是监听so ...
- Python自动化办公知识点整理汇总
知乎上有人提问:用python进行办公自动化都需要学习什么知识呢? 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手.很多已经做案例的人,却 ...
- 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队列 上节课回顾 进程: 进程的诞生时为了处理多任务,资源的隔离, ...
随机推荐
- SpringBoot之MongoTemplate的查询可以怎么耍
学习一个新的数据库,一般怎么下手呢?基本的CURD没跑了,当可以熟练的增.删.改.查一个数据库时,可以说对这个数据库算是入门了,如果需要更进一步的话,就需要了解下数据库的特性,比如索引.事物.锁.分布 ...
- requests.get()解析
1.requests.get(url, params=None, headers=None, cookies=None, auth=None, timeout=None) Sends a GET re ...
- Python学习之路:MINST实战第一版
1.项目介绍: 搭建浅层神经网络完成MNIST数字图像的识别. 2.详细步骤: (1)将二维图像转成一维,MNIST图像大小为28*28,转成一维就是784. (2)定义好神经网络的相关参数: # M ...
- 数学建模及机器学习算法(一):聚类-kmeans(Python及MATLAB实现,包括k值选取与聚类效果评估)
一.聚类的概念 聚类分析是在数据中发现数据对象之间的关系,将数据进行分组,组内的相似性越大,组间的差别越大,则聚类效果越好.我们事先并不知道数据的正确结果(类标),通过聚类算法来发现和挖掘数据本身的结 ...
- c++ undefinede reference to 构造函数/析构函数
g++编译器问题 把头文件"a.h"和头文件实现文件"a.cpp"都include就解决了.
- Django_信号
目录 Django信号介绍 Django内置信号 信号种类 信号注册 自定义信号 实测 内置信号 自定义信号 Django信号介绍 Django中提供了“信号调度”,用于在框架执行操作时解耦.通俗来讲 ...
- Django_杂
1.url带一些GET参数"url?a=1&b=2",通过QueryDict以及其urlencode()进行处理 from django.http.request impo ...
- 导出excel失败,提示提示加载类型库/DDL出错
首先,这里提供的解决办法仅适用于出现如下异常的情况:无法将类型为“Microsoft.Office.Interop.Excel.ApplicationClass”的 COM 对象强制转换为接口类型“M ...
- oo第八次作业--5,6,7次作业总结
一.多线程的设计 这三次作业的主要内容就是使用多线程并且解决多线程中出现的问题.而对于多线程我也有了自己的理解.首先明确的一点是单个CPU在同一时间只能处理一件事.那么,不管是多进程还是多线程,我们的 ...
- 【每日scrum】第一次冲刺day2
和小伙伴一起找地图 ,学习了mapinfo地图格式的基本知识,数据和图像分开存储