码迷,mamicode.com
首页 > 编程语言 > 详细

python运维开发之第二天

时间:2016-08-05 13:54:03      阅读:347      评论:0      收藏:0      [点我收藏+]

标签:

一、模块初识:

1、模块定义

python是由一系列的模块组成的,每个模块就是一个py为后缀的文件,同时模块也是一个命名空间,从而避免了变量名称冲突的问题。模块我们就可以理解为lib库,如果需要使用某个模块中的函数或对象,则要导入这个模块才可以使用,除了系统默认的模块不需要导入外。

 2、os,sys,paltform模块

模块导入import module

技术分享
import sys,os
print(------打印环境变量------)
print(打印sys.path结果,sys.path)
print(------打印脚本相对路径,在cmd中执行可以看出来------)
print(打印sys.argv结果,sys.argv)
print(----------------------#执行命令不保存结果,只返回执行状态-----------------------------------------)
cmd_output = os.system("dir")
print(打印os.system("dir")结果,cmd_output)
print(-----------#输出内存地址,需要read读取出结果--------------------)
rmd_res = os.popen("dir").read()
print("打印os.popen(‘dir‘).read()结果",rmd_res)
print(------------ 创建新文件夹(目录)------------------------------------------)
os.mkdir(new_dir)
os,sys模块

a、 os模块拓展

Python的标准库中的os模块主要涉及普遍的操作系统功能。可以在Linux和Windows下运行,与平台无关。

os.name字符串指示你正在使用的平台。比如对于Windows,它是‘nt‘,而对于Linux/Unix用户,它是‘posix‘。
os.getcwd()函数得到当前工作目录,即当前Python脚本工作的目录路径。

技术分享

os.getenv()和os.putenv()函数分别用来读取和设置环境变量。

技术分享

os.listdir()返回指定目录下的所有文件和目录名。

技术分享

os.remove()函数用来删除一个文件。

os.system()函数用来运行shell命令。

技术分享清屏

技术分享 

os.linesep字符串给出当前平台使用的行终止符。例如,Windows使用‘\r\n‘,Linux使用‘\n‘而Mac使用‘\r‘。

 技术分享

os.path.split()函数返回一个路径的目录名和文件名。

技术分享

os.path.isfile()和os.path.isdir()函数分别检验给出的路径是一个文件还是目录。

os.path.exists()函数用来检验给出的路径是否真地存在 

技术分享

os.listdir(dirname):列出dirname下的目录和文件

技术分享

os.chdir(dirname):改变工作目录到dirname

技术分享

os.path.getsize(name):获得文件大小,如果name是目录返回0L

技术分享

os.path.abspath(name):获得绝对路径

技术分享

os.path.normpath(path):规范path字符串形式
os.path.split(name):分割文件名与目录(事实上,如果你完全使用目录,它也会将最后一个目录作为文件名而分离,同时它不会判断文件或目录是否存在)

技术分享

os.path.splitext():分离文件名与扩展名

os.path.join(path,name):连接目录与文件名或目录

os.path.basename(path):返回文件名

os.path.dirname(path):返回文件路径

技术分享

 

b、sys模块拓展

sys.argv           命令行参数List,第一个元素是程序本身路径 
sys.modules.keys() 返回所有已经导入的模块列表

 技术分享

sys.exc_info()     获取当前正在处理的异常类,exc_type、exc_value、exc_traceback当前处理的异常详细信息 

技术分享

sys.exit(n)        退出程序,正常退出时exit(0) 

sys.hexversion     获取Python解释程序的版本值,16进制格式如:0x020403F0 

sys.version        获取Python解释程序的版本信息 

技术分享

sys.maxint         最大的Int值 
sys.maxunicode     最大的Unicode值 
sys.modules        返回系统导入的模块字段,key是模块名,value是模块 
sys.path           返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值 
sys.platform       返回操作系统平台名称 

sys.exc_clear()    用来清除当前线程所出现的当前的或最近的错误信息

sys.exec_prefix    返回平台独立的python文件安装的位置

技术分享

sys.byteorder      本地字节规则的指示器,big-endian平台的值是‘big‘,little-endian平台的值是‘little‘
sys.copyright      记录python版权相关的东西
sys.api_version    解释器的C的API版本

技术分享

sys.stdin,sys.stdout,sys.stderr变量包含与标准I/O流对应的流对象.如果需要更好地控制输出,而print不能满足你的要求,它们就是你所需要的.你也可以替换它们,这时候你就可以重定向输出和输入到其它设备(device),或者以非标准的方式处理它们

c、platform模块

platform.system()获取操作系统类型,windows、linux等

platform.platform()获取操作系统,Darwin-9.8.0-i386-32bit

platform.version()获取系统版本信息6.2.0

platform.mac_ver()

platform.win32_ver()(‘post2008Server‘,‘6.2.9200‘,‘‘,u‘MultiprocessorFree‘)

技术分享

 

二 、    .pyc文件

1、什么是pyc文件

pyc 是由py文件经过编译后二进制文件,py文件变成pyc文件后,加载的速度有所提高,而且pyc是一种跨平台的字节码,是由python 的虚 拟机来执行的。pyc的内容,是跟python的版本相关的,不同版本编译后的pyc文件是不同的,2.5编译的pyc文件,2.4版本的 python是无法执行的。pyc文件也是可以反编译的,不同版本编译后的pyc文件是不同。

2、为什么需要pyc文件

这个需求太明显了,因为py文件是可以直接看到源码的,如果你是开发商业软件的话,不可能把源码也泄漏出去吧?所以就需要编译为pyc后,再发布出去。

3、pycodeobject与pyc文件关系

[CodeObject.py]

技术分享
 1 class A :
 2 
 3     pass
 4 
 5 def Fun():
 6 
 7     pass
 8 
 9 a = A() 
10 
11 Fun()
View Code

在Python编译完成后,一共会创建3个PyCodeObject对象,一个是对应CodeObject.py的,一个是对应class A这段Code(作用域),而最后一个是对应def Fun这段Code的。每一个PyCodeObject对象中都包含了每一个代码块经过编译后得到的byte code。但是不幸的是,Python在执行完这些byte code后,会销毁PyCodeObject,所以下次再次执行这个.py文件时,Python需要重新编译源代码,创建三个PyCodeObject,然后执行byte code。

很不爽,对不对?Python应该提供一种机制,保存编译的中间结果,即byte code,或者更准确地说,保存PyCodeObject。事实上,Python确实提供了这样一种机制——Pyc文件。

参考地址:http://my.oschina.net/renwofei423/blog/17404

 三、数据类型

1、数字(整型,长整型,浮点型)(int,long,float)

技术分享
x的值22,y的值3
#######################返回绝对值######################
abs(-x)
22
#######################加减乘除#######################
x+y,x-y,x*y,x/y
25 19 66 7.333333333333333
###################取商,浮点数相除保留余数###################
x/y
7.333333333333333
###################取商,浮点数相除余数为0###################
x//y
7
########################取余########################
x%y
1
########################幂次方#######################
x**y
10648

####################################################
def __cmp__(self, y):
    """ 比较两个数大小 """
    """ x.__cmp__(y) <==> cmp(x,y) """
    pass

def __coerce__(self, y):
    """ 强制生成一个元组 """
    """ x.__coerce__(y) <==> coerce(x, y) """
    pass

def __divmod__(self, y):
    """ 相除,得到商和余数组成的元组 """
    """ x.__divmod__(y) <==> divmod(x, y) """
    pass

######################转换为浮点型######################
float(33)
33.0
######################转换为字符串######################
<class int>
str(x)
<class str>
######################转换为16进制#####################
x=22,x数据类型<class int>
hex(x)
0x16
######################转换为8进制######################
x=22,x数据类型<class int>
oct(x)
0o26
运算

 2、字符串(string)

技术分享
name=abcdefg abcd
#######################首字母大写######################
name.capitalize()
Abcdefg abcd
###################### 长度20居中#####################
name.center(20)
    abcdefg abcd    
################## 长度20里居中,其他用*填充#################
name.center(20,"*")
****abcdefg abcd****
#################长度20居左,rjust()居右#################
name.ljust(20)
abcdefg abcd        
#####################字符串里a的个数#####################
name.count(a)
2
###################字符串指定区域里a的个数###################
name.count(a,0,10)
2
####################字符串是否以bc为结尾###################
name.endswith(bc)
False
#################把tab键转换为空格,默认8个空格################
name.expandtabs(8)
abcdefg abcd
############找字符b的下标,找不到返回-1,如果有多个只找第一个############
name.find(b)
1
###################找字符b的下标,找不到报错##################
name.index(b)
1
####################判断是否为字母或数字####################
name.isalnum()
False
######################判断是否为字母#####################
name.isalpha()
False
######################判断是否为数字#####################
name.isdigit()
False
######################判断是否小写######################
name.islower()
True
#####################判断是否都是空格#####################
name.isspace()
False
#####################判断是否全是大写#####################
name.isupper()
False
#######################全变小写#######################
name.lower()
abcdefg abcd
###########全变大写,name值并没变,name.upper()输出大写#########
name.upper()
ABCDEFG ABCD
print(name)的值
abcdefg abcd
####################大写变小写,小写变大写###################
name.swapcase()
abcdefg abcd
##################### 符合的全部替换#####################
name.replace(c,d)
abddefg abdd
####################移除空格字符两边空格####################
name.strip()
abcdefg abcd
#######################以b为分割######################
name.split(b)
[a, cdefg a, cd]
###################### #join######################
###################把列表的元素用*连接起来###################
li=["aa","bb"]
*.join(li)
aa*bb
###############变为标题,标题(所有首字母大写就是标题)###############
name.title()
Abcdefg Abcd
######################判断是不是标题#####################
name.istitle()
False
#####################partition####################
name=aaccbb
#################分割成3部分 (aa,bb,cc)################
name.partition("cc")
(aa, cc, bb)
字符串方法

3、列表(list)

列表是Python中最基本的数据结构,列表是最常用的Python数据类型,列表的数据项不需要具有相同的类型。列表中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推。
Python有6个序列的内置类型,但最常见的是列表和元组。序列都可以进行的操作包括索引,切片,加,乘,检查成员。此外,Python已经内置确定序列的长度以及确定最大和最小的元素的方法。

a、切片

技术分享
names = ["xzmly","cjk","wtl","bdyjy"]
#打印列表索引位第二个
names[1]
cjk
#打印列表第一个到第二个位置的元素 也可以写成 print(names[:2])
names[0:2]
[xzmly, cjk]
#打印列表倒数第三和第二个元素,这里的-1不能够省略
names[-3:-1]
[cjk, wtl]
#打印列表倒数3个元素
names[-3:]
[cjk, wtl, bdyjy]
#打印整个列表隔个打印,即步长为2,也可以写成print(names[::2])
names[0:-1:2]
[xzmly, wtl]
View Code

b、追加

技术分享
names = ["xzmly","cjk","wtl","bdyjy"]
-----------#追加-------------
#列表最后添加一个元素"lzll"
names.append("lzll")
names值
[xzmly, cjk, wtl, bdyjy, lzll]
#列表索引位1前,插入“jzmb”,即原来的元素索引位1变为2
names.insert(1,"jzmb")
names值
[xzmly, jzmb, cjk, wtl, bdyjy, lzll]
View Code

c、改

技术分享
names = ["xzmly","cjk","wtl","bdyjy"]
----------#修改--------------
names[0] = "wangdana"
查看names第一个元素变为"wangdana"
[wangdana, cjk, wtl, bdyjy]
View Code

d、删

技术分享
names = ["xzmly","cjk","wtl","bdyjy"]
-----------#删除------------
-----------#这里删除里面是要知道具体的元素------------
names.remove("bdyjy")
#以下删除的是索引对应的元素,也可以写成names.pop(0)
del names[0]
names值
[cjk, wtl]
#删除names中索引为1的元素,不加索引,默认是删除最后一个元素
names.pop(1)
names值
[cjk]
View Code

 e、查

技术分享
names = ["xzmly","cjk","wtl","bdyjy"]
#查,索引 print(names.index())
----------#查询打印出‘bdyjy‘的索引号--------------
print(names.index("bdyjy"))
3
[xzmly, cjk, wtl, bdyjy]
names.count("bdyjy")是统计列表names中"bdyjy"有1个
View Code

f、Python列表操作的函数和方法

列表操作包含以下函数:

(1)、len(list):列表元素个数 

技术分享
#!/usr/bin/python

list1, list2 = [123, xyz, zara], [456, abc]

print "First list length : ", len(list1);
print "Second list length : ", len(list2);
实例
技术分享
First list length :  3
Second lsit length :  2
结果

(2)、max(list):返回列表元素最大值 

技术分享
#!/usr/bin/python

list1, list2 = [123, xyz, zara, abc], [456, 700, 200]

print "Max value element : ", max(list1);
print "Max value element : ", max(list2);
实例
技术分享
Max value element :  zara
Max value element :  700
结果

(3)、min(list):返回列表元素最小值 

技术分享
#!/usr/bin/python

list1, list2 = [123, xyz, zara, abc], [456, 700, 200]

print "min value element : ", min(list1);
print "min value element : ", min(list2);
实例
技术分享
min value element :  123
min value element :  200
结果

(4)、list(seq):将元组转换为列表 

技术分享
#!/usr/bin/python
# -*- coding: UTF-8 -*-

aTuple = (123, xyz, zara, abc)
aList = list(aTuple)

print "列表元素 : ", aList
实例
技术分享
列表元素 :  [123, xyz, zara, abc]
结果

列表操作包含以下方法:
(1)、list.append(obj):在列表末尾添加新的对象
(2)、list.count(obj):统计某个元素在列表中出现的次数
(3)、list.extend(seq):在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)
(4)、list.index(obj):从列表中找出某个值第一个匹配项的索引位置
(5)、list.insert(index, obj):将对象插入列表
(6)、list.pop(obj=list[-1]):移除列表中的一个元素(默认最后一个元素),并且返回该元素的值
(7)、list.remove(obj):移除列表中某个值的第一个匹配项
(8)、list.reverse():反转列表中元素顺序
(9)、list.sort([func]):对原列表进行排序,按ascii码排序

 

关于列表您可能感兴趣的文章:

 4、元组(tuple)

Python的元组与列表类似,不同之处在于元组的元素不能修改。元组使用小括号,列表使用方括号。元组创建很简单,只需要在括号中添加元素,并使用逗号隔开即可。

a、创建空元组

 元组中只包含一个元素时,需要在元素后面添加逗号;元组与字符串类似,下标索引从0开始,可以进行截取,组合等。

tup1 = ()
tup1 = (50,)

b、元组的查跟列表相似,参考上面的列表,其中元组中的元素是不可变的。因此没有增删改,删除整个元组用 del tup1

c、元组函数有

(1)len(tuple)计算元组元素个数。(同上列表)

(2)max(tuple)返回元组中元素最大值。(同上列表)

(3)min(tuple)返回元组中元素最小值。(同上列表)

(4)tuple(seq)将列表转换为元组。

实例1:针对字典 会返回字典的key组成的tuple,元组返回自身

技术分享

实例2:

aList = [123, xyz, zara, abc]
aTuple = tuple(aList)
print ("Tuple elements : ", aTuple)
#结果
Tuple elements :  (123, xyz, zara, abc)

 5、字典(dictionary)

字典是另一种可变容器模型,且可存储任意类型对象。

字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号{}中 ,格式如下所示:

d = {key1 : value1, key2 : value2 }

键必须是唯一的,但值则不必。

值可以取任何数据类型,但键必须是不可变的,如字符串,数字或元组

a、字典查询

dict = {Name: Zara, Age: 7, Class: First}
print("dict[‘Name‘]: ", dict[Name])
print("dict[‘Age‘]: ", dict[Age])
print("dict[‘Alice‘]: ", dict[Alice])
dict[Name]:  Zara
dict[Age]:  7

#查询dict[‘Alice‘],查询字典里没有的键时,会报错如下 

Traceback (most recent call last): File "D:/Users/Administrator/PycharmProjects/s14/day2/test/dictionary.py", line 9, in <module> print("dict[‘Alice‘]: ", dict[Alice]) KeyError: Alice

b、增加及修改字典元素

dict = {Name: Zara, Age: 7, Class: First};
dict[Age] = 8  # update existing entry
dict[School] = "DPS School"  # Add new entry
print("dict[‘Age‘]: ", dict[Age])
print("dict[‘School‘]: ", dict[School])
#结果
dict[Age]:  8
dict[School]:  DPS School

c、删(del)

技术分享
dict1 = {Name: Zara, Age: 7, Class: First}
del dict1[Name]  # 删除键是‘Name‘的条目
print(dict1)
dict1.clear()  # 清空词典所有条目
print(dict1)
del dict1  # 删除词典
print(dict1)
实例
技术分享
{Age: 7, Class: First}
{}
  File "D:/Users/Administrator/PycharmProjects/s14/day2/test/dictionary.py", line 26, in <module>
    print(dict1)
NameError: name dict1 is not defined
结果

d、字典特性

(1)不允许同一个键出现两次(无序性)

(2)键必须不可变,所以可以用数字,字符串或元组充当,但是用列表就不行。

技术分享
dict = {[Name]: Zara, Age: 7}
输出结果
Traceback (most recent call last):
  File "D:/Users/Administrator/PycharmProjects/s14/day2/test/dictionary.py", line 27, in <module>
    dict = {[Name]: Zara, Age: 7};
TypeError: unhashable type: list
实例及结果

e、字典内置函数及方法

(1)len(dict)  计算字典元素个数,即键的总数

(2)str(dict)  及type(dict)

技术分享
dict1 = {Name: Zara, Age: 7}
print(dict1)
print(type(dict1))
print(type(str(dict1)))
#结果
{Name: Zara, Age: 7}
<class dict>
<class str>
实例及结果

 (3)clear(dict) 删除字典中的所有元素

技术分享
dict = {Name: Zara, Age: 7}
print ("Start Len : %d" %  len(dict))
dict.clear()
print ("End Len : %d" %  len(dict))
#结果
Start Len : 2
End Len : 0
View Code

(4)dict.fromkeys(seq[,value])  用于创建一个新字典,以序列seq中元素做字典的键,value为字典所有键对应的初始值。

技术分享
seq = (name, age, sex) #或者seq = [‘name‘, ‘age‘, ‘sex‘]
dict = dict.fromkeys(seq)
print ("New Dictionary : %s" %  str(dict))
dict = dict.fromkeys(seq,10)
print ("New Dictionary : %s" %  str(dict))
#结果
New Dictionary : {sex: None, age: None, name: None}
New Dictionary : {sex: 10, age: 10, name: 10}
View Code

(5)dict.get(key, default=None)  返回指定键的值,如果值不在字典中返回默认值。

dict = {Name: Zara, Age: 27}
print ("Value : %s" %  dict.get(Age))
print ("Value : %s" %  dict.get(Sex))
#结果
Value : 27
Value : None

(6)dict.items()  以列表返回可遍历的(键, 值) 元组数组。

技术分享
dict = {Name: Zara, Age: 7}
print ("Value : %s" %  dict.items())
#结果
Value : dict_items([(Age, 7), (Name, Zara)])
View Code

(7)dict.keys()   函数以列表返回一个字典所有的键。

dict = {Name: Zara, Age: 7}
print ("Value : %s" %  dict.keys())
#结果
Value : dict_keys([Name, Age])

 (8)dict.setdefault(key, default=None)  和get()方法类似, 如果键不已经存在于字典中,将会添加键并将值设为默认值。

dict = {Name: Zara, Age: 7}
print ("Value : %s" %  dict.setdefault(Age, None))
print ("Value : %s" %  dict.setdefault(Sex, None))
print(dict)
#结果
Value : 7
Value : None
{Age: 7, Sex: None, Name: Zara}

(9)dict.update(dict2)  把字典dict2的键/值对更新到dict里;存在即替换,不存在即添加。

dict = {Name: Zara, Age: 7}
dict2 = {"Name":"John",Sex: female }
dict.update(dict2)
print("Value : %s" %  dict)
#结果
Value : {Sex: female, Age: 7, Name: John}

三、bytes

Python 3最重要的新特性大概要算是对文本和二进制数据作了更为清晰的区分。文本总是Unicode,由str类型表示,二进制数据则由bytes类型表示。Python 3不会以任意隐式的方式混用str和bytes,正是这使得两者的区分特别清晰。你不能拼接字符串和字节包,也无法在字节包里搜索字符串(反之亦然),也不能将字符串传入参数为字节包的函数(反之亦然)。这是件好事。

a = 我是谁!
print(a.encode(encoding=utf-8))
print(-------------------------------)
print(a.encode(encoding=utf-8).decode(encoding=utf-8))
#结果
b\xe6\x88\x91\xe6\x98\xaf\xe8\xb0\x81\xef\xbc\x81
-------------------------------
我是谁!

四、三元运算

result = 值1 if 条件 else 值2

技术分享

 如果a<b ,d的值等于a,否则d的值等于c

python运维开发之第二天

标签:

原文地址:http://www.cnblogs.com/willpower-chen/p/5736115.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!