1.这是python的语言特性,python先创建对象,在给变量赋值时,不需要定义变量的名称和类型,它实际是用变量引用对象。变量类型在给变量赋值时自动声明

2.原因类似变量无须声明类型

3.python用下划线作为变量前缀和后缀指定特殊变量,对解释器有特殊意义,也是内建标识符所使用的特殊符号,故一般避免用下划线作为变量的开头和结尾

4.python一行可以书写多个语句,多个语句间用";"分隔。但是为了良好的编程风格,不推荐这么做

5.python可以将一个语句分成多行书写,行的末尾用反斜杠"\"标识。python一行语句最好不超过80字符,所以若一个语句过长,可以分成多行书写。其他情况下,还是保持一个物理行写一个逻辑行吧

6.变量赋值

(a)赋值语句 x, y, z = 1, 2, 3  在x中赋值1,y中赋值2,z中赋值3

(b)执行在z, x, y = y, z, x后,x值是3,y的值是1,z的值是2

7.标识符

int32;printf;print;_print;this;self;__name__;bool;true;type;thisIsAVar;R_U_ready;Int;True;if;do;access

是合法的python标识符

其中,print;if是python关键字。

8.

#!/user/bin/env python
# -*- coding:utf-8 -*- 'makeTextFile.py -- create text file' import os
ls = os.linesep while True:
fname = raw_input("请输入要创建的文件名".decode("utf-8").encode("gbk"))
#判断文件是否已经存在,如果存在则重新输入
if os.path.exists(fname):
print u"错误:'%s' 文件已经存在!" % fname
else:
break
all = []
print u"\n 请输入每一行的内容,在单行输入英文状态的'.'完成输入。\n" while True:
entry = raw_input("输入没一行的内容吧:\n".decode("utf-8").encode("gbk"))
#判断输入内容是否是退出字符,若是则结束输入
if entry == '.':
break
else:
all.append(entry)
#创建文件,并以写入模式打开
fobj = open(fname,'w')
#将输入的每行写入文件中
fobj.writelines(['%s%s' % (x,ls) for x in all])
fobj.close()
print u"成功创建!程序结束!"

9.操作系统:Windows 10 64位

os.linesep:'\r\n'

10.① try-except-else 替代

#!/user/bin/env python
# -*- coding:utf-8 -*- 'makeTextFile.py -- create text file' import os
ls = os.linesep while True:
fname = raw_input("请输入要创建的文件名".decode("utf-8").encode("gbk"))
#判断文件是否已经存在,如果存在则重新输入
try:
fobj = open(fname)
except IOError: break
else:
print u"错误:%s 文件已经存在" % fname all = []
print u"\n请输入每一行的内容,在单行输入英文状态的'.'完成输入。\n" while True:
entry = raw_input("输入每一行的内容吧:\n".decode("utf-8").encode("gbk"))
#判断输入内容是否是退出字符,若是则结束输入
if entry == '.':
break
else:
all.append(entry)
#创建文件,并以写入模式打开
fobj = open(fname,'w')
#将输入的每行写入文件中
fobj.writelines(['%s%s' % (x,ls) for x in all])
fobj.close()
print u"成功创建!程序结束!"

②os.path.exists()替换try-except-else

#!/user/bin/env python
# -*- coding:utf-8 -*- 'readTextFile.py -- read and display text file' import os
#用户输入要打开的文件
fname = raw_input("请输入文件名:") print #尝试以阅读模式打开文件 if os.path.exists(fname):
fobj = open(fname,'r')
for eachline in fobj:
print eachline,
fobj.close()
else:
print "错误:文件不存在!"

11.

#!/user/bin/env python
# -*- coding:utf-8 -*- "readTextFile.py -- read and display text file" #用户输入要打开的文件
fname = raw_input("Enter file name".decode("utf-8").encode("gbk")) print #尝试以阅读模式打开文件 try:
fobj = open(fname,'r')
except IOError,e:
print "*** file open error:",e
else:
#打印出文件内容
for eachline in fobj:
print eachline.strip('\n')
fobj.close()

给自己的提示:字符串的strip()方法用于移除字符串头尾指定的字符,它返回移除指定字符后的新字符串

eg:

str = "11111Let's see how the strip() works.1111111"
print str.strip('')

输出:

Let's see how the strip() works.

12.修改后程序如下

#!user/bin/env python
# -*- coding:utf-8 -*- 'read_or_makeTextFile.py -- read and display text file,or create text file ' import os
ls = os.linesep while True:
choise = raw_input("打开文件请输入1,创建文件输入2,退出输入3:".decode("utf-8").encode("gbk")) if not choise.isdigit():
print u"请输入数字"
elif int(choise) == 1:
fname = raw_input("请输入文件名:".decode("utf-8").encode("gbk")) print #尝试以阅读模式打开文件 if os.path.exists(fname):
fobj = open(fname,'r')
for eachline in fobj:
print eachline,
fobj.close()
else:
print "错误:文件不存在!"
elif int(choise) == 2:
while True:
fname = raw_input("请输入要创建的文件名".decode("utf-8").encode("gbk"))
#判断文件是否已经存在,如果存在则重新输入
if os.path.exists(fname):
print u"错误:'%s' 文件已经存在!" % fname
else:
break
all = []
print u"\n请输入每一行的内容,在单行输入英文状态的'.'完成输入。\n" while True:
entry = raw_input("输入每一行的内容吧:\n".decode("utf-8").encode("gbk"))
#判断输入内容是否是退出字符,若是则结束输入
if entry == '.':
break
else:
all.append(entry)
#创建文件,并以写入模式打开
fobj = open(fname,'w')
#将输入的每行写入文件中
fobj.writelines(['%s%s' % (x,ls) for x in all])
fobj.close()
print u"成功创建!程序结束!"
elif int(choise) == 3:
print u"程序将退出"
break
else:
print u"请重新输入"

13.修改后程序如下

 #!user/bin/env python
# -*- coding:utf-8 -*- 'read_or_makeTextFile.py -- read and display text file,or create text file ' import os
ls = os.linesep
print os.getcwd()
while True:
choise = raw_input("打开文件请输入1,创建文件输入2,编辑文件输入3,退出输入4:".decode("utf-8").encode("gbk")) if not choise.isdigit():
print u"请输入数字"
elif int(choise) == 1:
fname = raw_input("请输入文件名:".decode("utf-8").encode("gbk")) print #尝试以阅读模式打开文件 if os.path.exists(fname):
fobj = open(fname,'r')
for eachline in fobj:
print eachline,
fobj.close()
else:
print u"错误:文件不存在!"
elif int(choise) == 2:
while True:
fname = raw_input("请输入要创建的文件名".decode("utf-8").encode("gbk"))
#判断文件是否已经存在,如果存在则重新输入
if os.path.exists(fname):
print u"错误:'%s' 文件已经存在!" % fname
else:
break
all = []
print u"\n请输入每一行的内容,在单行输入英文状态的'.'完成输入。\n" while True:
entry = raw_input("输入每一行的内容吧:\n".decode("utf-8").encode("gbk"))
#判断输入内容是否是退出字符,若是则结束输入
if entry == '.':
break
else:
all.append(entry)
#创建文件,并以写入模式打开
fobj = open(fname,'w')
#将输入的每行写入文件中
fobj.writelines(['%s%s' % (x,ls) for x in all])
fobj.close()
print u"成功创建!程序结束!"
elif int(choise) == 3:
fname = raw_input("请输入文件名:".decode("utf-8").encode("gbk"))
print #尝试以读写模式("r+")模式打开文件
if os.path.exists(fname):
fobj = open(fname)
count = len(fobj.readlines())
fobj.close()
lines = []
for i in range(1,count):
line = raw_input("请输入修改后的每行的内容:".decode("utf-8").encode("gbk"))
lines.append(line)
while True:
save = raw_input("保存修改输入1,不保存输入2:".decode("utf-8").encode("gbk"))
if not save.isdigit():
print u"请输入数字1保存或者2不保存!!"
elif int(save) == 1:
fobj = open(fname,'w')
fobj.writelines(['%s%s' % (x,ls) for x in lines])
fobj.close
print u"修改成功!"
break
elif int(save) == 2:
break
else:
print u"错误!文件不存在!" elif int(choise) == 4:
print u"程序将退出"
break
else:
print u"请重新输入"

python核心编程-第三章-习题的更多相关文章

  1. 【1】python核心编程 第三章

    1.继续( \ ) 有两种例外情况一个语句不使用反斜线也可以跨行.在使用闭合操作符时,单一语句可以跨多行,例如:在含有小括号.中括号.花括号时可以多行书写.另外就是三引号包括下的字符串也可以跨行书写 ...

  2. python核心编程-第三章-个人笔记

    1.语句和语法 (1)反斜杠"\"表示语句继续.python良好的编程习惯是一行最后不超过80个字符,一行字符过多时便须用到反斜杠换行继续该语句. PS:在使用小括号.中括号.大括 ...

  3. python核心编程-第五章-习题

    1.长整型表示数的范围比整型更大.在python中,整型.长整型趋于统一,普通用户不用特别关注两者区别,仅当需引用C语言时需要特别注意. 2.操作符 (a) def product(x,y): ret ...

  4. python核心编程-第四章-习题

    1.身份.类型.值.其中,身份是每个对象的标识,与内存地址密切相关,可用id()返回:类型决定了对象可以保存什么类型的值,用type()函数.isinstance()函数可以得到对象的类型:值就是对象 ...

  5. 《Python核心编程》部分代码习题实践(持续更新)

    第三章 3-10 交换异常处理方式 代码: #makeTextFile.py #!/usr/bin/env python 'makeTextFile.py' import os ls = os.lin ...

  6. 【7】python核心编程 第十一章-函数和函数式编程

    1.*函数(与方法)装饰器 装饰器背后的主要动机源自python 面向对象编程.装饰器是在函数调用之上的修饰.这些修饰 仅是当声明一个函数或者方法的时候,才会应用的额外调用. 装饰器的语法以@开头,接 ...

  7. python核心编程-第四章-个人笔记

    1.所有的python对象都拥有三个特性: ①身份:每个对象都有唯一的身份标识自己,可用内建函数id()来得到.基本不会用到,不用太关心 >>> a = 2 >>> ...

  8. Python核心编程第三版第二章学习笔记

    第二章 网络编程 1.学习笔记 2.课后习题 答案是按照自己理解和查阅资料来的,不保证正确性.如由错误欢迎指出,谢谢 1. 套接字:A network socket is an endpoint of ...

  9. python 核心编程第二版 课后习题 第11章

    11-3 函数.在这个练习中,我们将实现 max()和 min()内建函数. (a) 写分别带两个元素返回一个较大和较小元素,简单的 max2()核 min2()函数.他们应该可以用任意的 pytho ...

随机推荐

  1. 移动web前端的一些硬技能(二)动手前必须掌握的基本常识

    记得刚开始接触移动端web的时候,书和网上的资料都不多,查起来很费劲,现在比以前要好很多了,可是还是会有一些刚接触移动端的朋友会问我一些我最初会遇到的问题,或许是书本写的并不那么重,也或许是这些知识写 ...

  2. jquery find()和filter()的区别

    在写js查找当前标签下某一子元素的子元素集合时,用到了此方法 $(".flyout-trigger").mouseover(function(){ var maxnum=$(thi ...

  3. 【转】Tomcat集群Cluster实现原理剖析

    此文章来源:http://zyycaesar.iteye.com/blog/296606 此文章作者:zyycaesar 对于WEB应用集群的技术实现而言,最大的难点就是如何能在集群中的多个节点之间保 ...

  4. iOS开发之OC篇-响应式编程Reactive Cocoa

    一.Reactive Cocoa 介绍 Reactive Cocoa 是 iOS 开发的一个 "重量级" 框架 高大上的概念:响应式编程 核心概念:信号 Signal 官方网站:h ...

  5. wordpress教程之文章页single.php获取当前文章所属分类

    之所以要发这篇文章,是因为这个方法适用于: WP默认文章分类 手动添加的自定文章分类 插件(custom post type ui)添加的自定义文章分类(含taxonomy) 方法目的:在文章模板中, ...

  6. C51编程中对单片机绝对地址访问的两种方法

    在进行8051单片机应用系统程序设计时,编程都往往少不了要直接操作系统的各个存储器地址空间.C51程序经过编译之后产生的目标代码具有浮动地址,其绝对地址必须经过BL51连接定位后才能确定.为了能够在C ...

  7. javascript之尺寸,位置,溢出

    一.offsetWidth:元素的宽度,包括边框,内容,内边距. 二.offsetHeight:元素的高度,包括边框,内容,内边距. 三.offsetLeft:元素的X坐标(相对于最近已定位的祖先元素 ...

  8. 【原创整理,基于JavaScript的创建对象方式的集锦】

    以下4种方式,是我在项目中最常见的JavaScript的面向对象的方式的开发. 测试一般在微软的工具:http://www.typescriptlang.org/Playground 进行测试,或者使 ...

  9. css案例学习之双斜角横线菜单

    效果 代码 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w ...

  10. 【剑指offer】面试题23:从上往下打印二叉树

    题目: 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 思路: bfs,队列. 注意,队列最后不要忘了pop(). 代码: /* struct TreeNode { int val; stru ...