1小时学Python脚本

时间:2024-03-28 00:07:32

如果我们有这么一项任务:简单測试局域网中的电脑是否连通.这些电脑的ip范围从192.168.0.101到192.168.0.200.   





    思路:用shell编程.(Linux一般是bash而Windows是批处理脚本).比如,在Windows上用ping ip 的命令依次測试各个机器并得到控制台输出.因为ping通的时候控制台文本一般是"Reply from ... " 而不通的时候文本是"time out ... " ,所以,在结果中进行字符串查找,就可以知道该机器是否连通.





    实现:Java代码例如以下:





String cmd="cmd.exe ping ";

String ipprefix="192.168.10.";

int begin=101;

int end=200;

Process p=null;





for(int i=begin;i<end;i++){

     p= Runtime.getRuntime().exec(cmd+i);

     String line = null;

     BufferedReader reader = new BufferedReader(new InputStreamReader(p.getInputStream()));

     while((line = reader.readLine()) != null)

     {

         //Handling line , may logs it. 

     }

    reader.close();

    p.destroy();

}





    这段代码执行得非常好,问题是为了执行这段代码,你还须要做一些额外的工作.这些额外的工作包含:





编写一个类文件 

编写一个main方法 

将之编译成字节代码 

因为字节代码不能直接执行,你须要再写个小小的bat或者bash脚本来执行.

    当然,用C/C++相同能完毕这项工作.但C/C++不是跨平台语言.在这个足够简单的样例中或许看不出C/C++和Java实现的差别,但在一些更为复杂的场景,比方要将连通与否的信息记录到网络数据库.因为Linux和Windows的网络接口实现方式不同,你不得不写两个函数的版本号.用Java就没有这种顾虑.





    相同的工作用Python实现例如以下:









import subprocess





cmd="cmd.exe"

begin=101

end=200

while begin<end:





    p=subprocess.Popen(cmd,shell=True,stdout=subprocess.PIPE,

                   stdin=subprocess.PIPE,

                   stderr=subprocess.PIPE)

    p.stdin.write("ping 192.168.1."+str(begin)+"\n")





    p.stdin.close()

    p.wait()





    print "execution result: %s"%p.stdout.read()





    对照Java,Python的实现更为简洁,你编写的时间更快.你不须要写main函数,而且这个程序保存之后能够直接执行.另外,和Java一样,Python也是跨平台的.





    有经验的C/Java程序猿可能会争论说用C/Java写会比Python写得快.这个观点见仁见智.我的想法是当你同一时候掌握Java和Python之后,你会发现用Python写这类程序的速度会比Java快上很多.比如操作本地文件时你仅须要一行代码而不须要Java的很多流包装类.各种语言有其天然的适合的应用范围.用Python处理一些简短程序类似与操作系统的交互编程工作最省时省力.





--------------------------------------------------------------------------------









Python应用场合

    足够简单的任务,比如一些shell编程.假设你喜欢用Python设计大型商业站点或者设计复杂的游戏,悉听尊便.





--------------------------------------------------------------------------------





2 高速入门2.1 Hello world





    安装完Python之后(我本机的版本号是2.5.4),打开IDLE(Python GUI) , 该程序是Python语言解释器,你写的语句可以马上执行.我们写下一句著名的程序语句:





print "Hello,world!"

    并按回车.你就能看到这句被K&R引入到程序世界的名言.





    在解释器中选择"File"--"New Window" 或快捷键 Ctrl+N , 打开一个新的编辑器.写下例如以下语句:





print "Hello,world!"

raw_input("Press enter key to close this window");

    保存为a.py文件.按F5,你就能够看到程序的执行结果了.这是Python的另外一种执行方式.





    找到你保存的a.py文件,双击.也可以看到程序结果.Python的程序可以直接执行,对照Java,这是一个优势.





--------------------------------------------------------------------------------









2.2 国际化支持

    我们换一种方式来问候世界.新建一个编辑器并写例如以下代码:





print "欢迎来到奥运中国!"

raw_input("Press enter key to close this window");

    在你保存代码的时候,Python会提示你是否改变文件的字符集,结果例如以下:





# -*- coding: cp936 -*- 





print "欢迎来到奥运中国!"

raw_input("Press enter key to close this window");

    将该字符集改为我们更熟悉的形式:





# -*- coding: GBK -*- 





print "欢迎来到奥运中国!" # 使用中文的样例

raw_input("Press enter key to close this window");

    程序一样执行良好.





--------------------------------------------------------------------------------





2.3 方便易用的计算器





    用微软附带的计算器来计数实在太麻烦了.打开Python解释器,直接进行计算:





a=100.0

b=201.1

c=2343

print (a+b+c)/c









--------------------------------------------------------------------------------





2.4 字符串,ASCII和UNICODE





    能够例如以下打印出提前定义输出格式的字符串:





print """

Usage: thingy [OPTIONS]

     -h                        Display this usage message

     -H hostname               Hostname to connect to

"""

    字符串是怎么訪问的?请看这个样例:





word="abcdefg"

a=word[2]

print "a is: "+a

b=word[1:3]

print "b is: "+b # index 1 and 2 elements of word.

c=word[:2]

print "c is: "+c # index 0 and 1 elements of word.

d=word[0:]

print "d is: "+d # All elements of word.

e=word[:2]+word[2:]

print "e is: "+e # All elements of word.

f=word[-1]

print "f is: "+f # The last elements of word.

g=word[-4:-2]

print "g is: "+g # index 3 and 4 elements of word.

h=word[-2:]

print "h is: "+h # The last two elements.

i=word[:-2]

print "i is: "+i # Everything except the last two characters

l=len(word)

print "Length of word is: "+ str(l)

    请注意ASCII和UNICODE字符串的差别:





print "Input your Chinese name:"

s=raw_input("Press enter to be continued");

print "Your name is  : " +s;

l=len(s)

print "Length of your Chinese name in asc codes is:"+str(l);

a=unicode(s,"GBK")

l=len(a)

print "I'm sorry we should use unicode char!Characters number of your Chinese \

name in unicode is:"+str(l);





--------------------------------------------------------------------------------





2.5 使用List





    类似Java里的List,这是一种方便易用的数据类型:





word=['a','b','c','d','e','f','g']

a=word[2]

print "a is: "+a

b=word[1:3]

print "b is: "

print b # index 1 and 2 elements of word.

c=word[:2]

print "c is: "

print c # index 0 and 1 elements of word.

d=word[0:]

print "d is: "

print d # All elements of word.

e=word[:2]+word[2:]

print "e is: "

print e # All elements of word.

f=word[-1]

print "f is: "

print f # The last elements of word.

g=word[-4:-2]

print "g is: "

print g # index 3 and 4 elements of word.

h=word[-2:]

print "h is: "

print h # The last two elements.

i=word[:-2]

print "i is: "

print i # Everything except the last two characters

l=len(word)

print "Length of word is: "+ str(l)

print "Adds new element"

word.append('h')

print word





--------------------------------------------------------------------------------





2.6 条件和循环语句

# Multi-way decision

x=int(raw_input("Please enter an integer:"))

if x<0:

    x=0

    print "Negative changed to zero"





elif x==0:

    print "Zero"





else:

    print "More"









# Loops List

a = ['cat', 'window', 'defenestrate']

for x in a:

    print x, len(x)









--------------------------------------------------------------------------------





2.7 怎样定义函数

# Define and invoke function.

def sum(a,b):

    return a+b









func = sum

r = func(5,6)

print r





# Defines function with default argument

def add(a,b=2):

    return a+b

r=add(1)

print r

r=add(1,5)

print r

    而且,介绍一个方便好用的函数:





# The range() function

a =range(5,10)

print a

a = range(-2,-7)

print a

a = range(-7,-2)

print a

a = range(-2,-11,-3) # The 3rd parameter stands for step

print a





--------------------------------------------------------------------------------





2.8 文件I/O

spath="D:/download/baa.txt"

f=open(spath,"w") # Opens file for writing.Creates this file doesn't exist.

f.write("First line 1.\n")

f.writelines("First line 2.")





f.close()





f=open(spath,"r") # Opens file for reading





for line in f:

    print line





f.close()





--------------------------------------------------------------------------------





2.9 异常处理





s=raw_input("Input your age:")

if s =="":

    raise Exception("Input must no be empty.")





try:

    i=int(s)

except ValueError:

    print "Could not convert data to an integer."

except:

    print "Unknown exception!"

else: # It is useful for code that must be executed if the try clause does not raise an exception

    print "You are %d" % i," years old"

finally: # Clean up action

    print "Goodbye!"





--------------------------------------------------------------------------------









2.10 类和继承





class Base:

    def __init__(self):

        self.data = []

    def add(self, x):

        self.data.append(x)

    def addtwice(self, x):

        self.add(x)

        self.add(x)





# Child extends Base

class Child(Base):

    def plus(self,a,b):

        return a+b





oChild =Child()

oChild.add("str1")

print oChild.data

print oChild.plus(2,3)





--------------------------------------------------------------------------------









2.11 包机制

    每个.py文件称为一个module,module之间能够互相导入.请參看下面样例:

# a.py

def add_func(a,b):

    return a+b

# b.py

from a import add_func # Also can be : import a





print "Import add_func from module a"

print "Result of 1 plus 2 is: "

print add_func(1,2)    # If using "import a" , then here should be "a.add_func"





    module能够定义在包里面.Python定义包的方式略微有点古怪,如果我们有一个parent目录,该目录有一个child子目录.child中有一个module a.py . 怎样让Python知道这个文件层次结构?非常easy,每一个目录都放一个名为_init_.py 的文件.该文件内容能够为空.这个层次结构例如以下所看到的: 

parent 

  --__init_.py

  --child

    -- __init_.py

    --a.py





b.py

    那么Python怎样找到我们定义的module?在标准包sys中,path属性记录了Python的包路径.你能够将之打印出来:





import sys





print sys.path

    通常我们能够将module的包路径放到环境变量PYTHONPATH中,该环境变量会自己主动加入�到sys.path属性.还有一种方便的方法是编程中直接指定我们的module路径到sys.path 中:





import sys

sys.path.append('D:\\download')





from parent.child.a import add_func









print sys.path





print "Import add_func from module a"

print "Result of 1 plus 2 is: "

print add_func(1,2)





--------------------------------------------------------------------------------





总结    你会发现这个教程相当的简单.很多Python特性在代码中以隐含方式提出,这些特性包含:Python不须要显式声明数据类型,keyword说明,字符串函数的解释等等.我觉得一个熟练的程序猿应该对这些概念相当了解,这样在你挤出宝贵的一小时阅读这篇短短的教程之后,你可以通过已有知识的迁移类比尽快熟悉Python,然后尽快能用它開始编程.





    当然,1小时学会Python颇有哗众取宠之嫌.确切的说,编程语言包含语法和标准库.语法相当于武术招式,而标准库应用实践经验则类似于内功,须要长期锻炼.Python学习了Java的好处,提供了大量极方便易用的标准库供程序猿"拿来主义".(这也是Python成功的原因),在开篇我们看到了Python怎样调用Windows cmd的样例,以后我会尽量写上各标准库的使用方法和一些应用技巧,让大家真正掌握Python.





    但无论如何,至少你如今会用Python取代繁琐的批处理敲代码了.希望那些真的能在一小时内读完本文并開始使用Python的程序猿会喜欢这篇小文章,谢谢! 

具体出处參考:http://www.jb51.net/article/926.htm