#############################################################################

#############在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自动化之读写的更多相关文章

  1. python自动化运维学习第一天--day1

    学习python自动化运维第一天自己总结的作业 所使用到知识:json模块,用于数据转化sys.exit 用于中断循环退出程序字符串格式化.format字典.文件打开读写with open(file, ...

  2. python自动化开发学习 I/O多路复用

    python自动化开发学习 I/O多路复用   一. 简介 socketserver在内部是由I/O多路复用,多线程和多进程,实现了并发通信.IO多路复用的系统消耗很小. IO多路复用底层就是监听so ...

  3. Python自动化办公知识点整理汇总

    知乎上有人提问:用python进行办公自动化都需要学习什么知识呢? 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手.很多已经做案例的人,却 ...

  4. flow.ci + Github + Slack 一步步搭建 Python 自动化持续集成

    理想的程序员必须懒惰,永远追随自动化法则.Automating shapes smarter future. 在一个 Python 项目的开发过程中可能会做的事情:编译.手动或自动化测试.部署环境配置 ...

  5. Selenium2+python自动化23-富文本(自动发帖)

    前言 富文本编辑框是做web自动化最常见的场景,有很多小伙伴遇到了不知道无从下手,本篇以博客园的编辑器为例,解决如何定位富文本,输入文本内容 一.加载配置 1.打开博客园写随笔,首先需要登录,这里为了 ...

  6. Selenium2+python自动化24-js处理富文本(带iframe)

    前言 上一篇Selenium2+python自动化23-富文本(自动发帖)解决了富文本上iframe问题,其实没什么特别之处,主要是iframe的切换,本篇讲解通过js的方法处理富文本上iframe的 ...

  7. Selenium2+python自动化7-xpath定位

    前言 在上一篇简单的介绍了用工具查看目标元素的xpath地址,工具查看比较死板,不够灵活,有时候直接复制粘贴会定位不到.这个时候就需要自己手动的去写xpath了,这一篇详细讲解xpath的一些语法. ...

  8. Selenium2+python自动化13-Alert

    不是所有的弹出框都叫alert,在使用alert方法前,先要识别出它到底是不是alert.先认清楚alert长什么样子,下次碰到了,就可以用对应方法解决.alert\confirm\prompt弹出框 ...

  9. 【python自动化第十一篇】

    [python自动化第十一篇:] 课程简介 gevent协程 select/poll/epoll/异步IO/事件驱动 RabbitMQ队列 上节课回顾 进程: 进程的诞生时为了处理多任务,资源的隔离, ...

随机推荐

  1. 所有权链(Ownership Chain)

    所有权链(Ownership Chain)是特殊的权限评估方式,常见拥有所有权的数据库对象是:数据库对象,数据库角色(Role),和架构(Schema),在创建数据库角色,或架构时,SQL Serve ...

  2. Java动态代理:一个面包店的动态代理帝国

    文章首发于[博客园-陈树义],点击跳转到原文大白话说Java动态代理:一个面包店的动态代理帝国 代理模式是设计模式中非常重要的一种类型,而设计模式又是编程中非常重要的知识点,特别是在业务系统的重构中, ...

  3. linux安装anaconda3

    1,查看系统的版本  Uname –r 2,安装git 等依赖库 yum install git yum install zlib-devel bzip2-devel openssl-devel nc ...

  4. MySQL日志系统:redo log与binlog

    日志系统主要有redo log(重做日志)和binlog(归档日志).redo log是InnoDB存储引擎层的日志,binlog是MySQL Server层记录的日志, 两者都是记录了某些操作的日志 ...

  5. c语言数字图像处理(五):空间滤波

    空间滤波原理 使用大小为m*n的滤波器对大小为M*N的图像进行线性空间滤波,将滤波器模板乘以图像中对应灰度值,相加得模板中心灰度值 a = (m-1)/2, b = (n-1)/2 若f(x+s, y ...

  6. EventBus的基本使用步骤

    为什么要使用EventBus 当我们进行项目开发的时候,往往是需要应用程序的各组件间进行通信,比如在子线程中进行请求数据,当数据请求完毕后通过Handler或者是广播通知UI, 通常两个Activit ...

  7. Unity Shader 学习之旅之SurfaceShader

    Unity Shader 学习之旅之SurfaceShader unity shader 图形图像  如果大地的每个角落都充满了光明 谁还需要星星,谁还会 在夜里凝望 寻找遥远的安慰——江河 官方文档 ...

  8. 4星|《钱的历史》:大英博物馆的钱币简史,彩图众多不适合在kindle上阅读

    钱的历史(大英博物馆权威出品,一部金钱简史) 大英博物馆的两位钱币馆馆长的作品.非常专业.基本是世界钱币简史.从钱币的发展变迁讲到涉及到的历史大事,重心当然是欧洲的钱币史,中国.印度也各安排了一章. ...

  9. Dubbo问题处理集合

    1 . 启动微服务的时候,报错信息如下: 核心:Can not lock the registry cache file /root/.dubbo/dubbo-registry-127.0.0.1.c ...

  10. Ubuntu系统无法识别Logitech M590蓝牙鼠标的问题

    参见 - https://blog.csdn.net/yh2869/article/details/73119018 亲测可用. 系统:ubuntu 16.04 64bit 现象:鼠标配对可以成功,但 ...