|
Chapter_2_变量和简单数据类型
- <br># In[1]<br># 2.3 字符串<br>name = "ada loveada"<br>print(name.title())<br>print(name.upper())<br>print(name.isupper())<br>name = name.upper()<br>print(name.isupper())<br>print(name.lower())<br>print(name.swapcase()) # 大写变小写,小写变大写<br><br># 合并字符串 1<br>first_name = 'ada'<br>last_name = 'lovelace'<br>full_name = first_name + " " + last_name<br>print(full_name)<br># 合并字符串 2<br>print("Hello," + full_name.title() + "!")<br><br># 使用制表符或换行符来添加空白<br>print("\tpython")<br><br>'''删除空白----------要确保字符串末尾没有空白,可使用方法'''<br>favorite_language = "python "<br>print(len(favorite_language))<br>print(len(favorite_language.rstrip()))<br># 要永久删除这个字符串中的空白,必须将删除操作的结果存回到变量中<br>favorite_language = favorite_language.rstrip()<br># favorite_language = favorite_language.replace(" ","")<br>print(favorite_language)<br>print(favorite_language.rstrip("python"))<br>print('Monty Python'.rstrip(' Python'))<br><br># 2.3.5 使用字符串时避免语法错误<br><br># In[2]<br># 2.4 数字<br># 2.4.1 整数<br># 2.4.2 浮点数<br>'''<br>所有语言都存在这种问题,没有什么可担心的。Python会尽力找到一种方式,以尽可能精确<br>地表示结果,但鉴于计算机内部表示数字的方式,这在有些情况下很难。就现在而言,暂时忽略<br>多余的小数位数即可;在第二部分的项目中,你将学习在需要时处理多余小数位的方式。<br>'''<br><br>
复制代码 Chapter_3_列表简介
- # In[1]<br>""" 3.1 列表是什么? """<br>bicycles = ['tiek', 'cannondale', 'redline', 'specialized']<br>print(bicycles[0].title())<br>print(bicycles[-1])<br><br>""" 3.2 修改、添加和删除元素 """<br>'''3.2.1 修改列表元素'''<br>motorcycles = ['honda', 'yamaha', 'suzuki']<br>print(motorcycles[0])<br>motorcycles[0] = 'ducati'<br>print(motorcycles[0])<br><br>'''3.2.2 在列表中添加元素'''<br>motorcycles.append("asdad")<br>print(motorcycles)<br>motorcycles.insert(0, 'asdasdasd') # 方法insert()在索引0处添加空间,并将值'asdasdasd'存储到这个地方。<br>print(motorcycles)<br>'''3.2.3 从列表中删除元素'''<br># 使用 del<br>del motorcycles[0]<br>print(motorcycles)<br># 使用方法pop()删除元素,并接着使用它的值<br>motorcycles = ['honda', 'yamaha', 'suzuki']<br>poped_motorcycles = motorcycles.pop(0)<br>print(motorcycles)<br>print(poped_motorcycles)<br># 总结:如果你要从列表中删除一个元素,且不再以任何方式使用它,就使用del语句;如果你要在删除元素后还能继续使用它,就使用方法pop()。<br>'''4. 根据值删除元素'''<br>motorcycles = ['honda', 'honda', 'yamaha', 'suzuki']<br>print(motorcycles)<br>motorcycles.remove('honda') # 方法remove()只删除第一个指定的值<br>print(motorcycles)<br><br>''' 3.3 组织列表 '''<br>motorcycles = ['honda', 'yamaha', 'suzuki']<br>test_Sort = ['12', 'asd', '12.3', '123']<br>'''3.3.1 使用方法 sort()对列表进行永久性排序'''<br>motorcycles.sort()<br>print(motorcycles)<br>test_Sort = ['12', 'asd', '12.3', '123']<br>test_Sort.sort() # 永久性地修改了列表元素的排列顺序<br>print(test_Sort) # ['12', '12.3', '123', 'asd']<br>str_ = 'asdASDgh'<br>test_Sort.reverse()<br>str_ = str_.swapcase()<br>print(str_)<br>print(test_Sort)<br>'''3.3.2 使用函数 sorted()对列表进行临时排序'''<br>motorcycles = ['honda', 'Yamaha', 'yam', 'suzuki']<br>print(sorted(motorcycles))<br>print(motorcycles)<br>print(sorted(motorcycles, reverse=True))<br>print(motorcycles)<br><br># In[2]<br># 倒置字符串1<br>str_ = 'abcdefghijklmn'<br>list_str = []<br>for i in str_:<br> list_str.append(i)<br>list_str.reverse()<br>str_reverse = ''<br>for i in list_str:<br> str_reverse += i<br>print(str_reverse)<br><br># 倒置字符串2<br>print(str_[::])<br>print(str_[::-1])<br><br># 倒置字符串3<br>result = ''<br>for i in range(len(str_) - 1, -1, -1):<br> result += str_[i]<br>print(result)<br><br># In[2]<br>list_1 = {'string': '1', 'string2': 2}<br>list_2 = list_1<br>list_2.update({'string3': '3'})<br>print(list_1)<br>print(list_2)<br><br>'''<br>my_foods = ['pizza', 'falafel', 'carrot cake']<br>#friend_foods = my_foods[:]<br># VS<br>friend_foods = my_foods # 并非把副本存储到 friend_foods<br>my_foods.append('cannoli')<br>friend_foods.append('123')<br>print(friend_foods)<br>print(my_foods)<br>'''
复制代码 Chapter_4_操作列表
- # In[1]<br>magicians = ['alice', 'david', 'carolina']<br>for i in magicians:<br> print(i)<br>'''4.1.1 深入地研究循环'''<br>a = list(range(1, 10, 2))<br>print(a)<br>print(sum(a))<br><br>'''----------4.3.4 列表解析----------- '''<br># value = list(range[0,11,2])<br>squares = [value ** 2 for value in range(1, 11)]<br>print(squares)<br><br># 作业2 计算 1~1 000 000 的总和<br>numbers = list(range(1, 1000001))<br>sumNum = 0<br>for i in numbers:<br> sumNum += i<br>result = sum(numbers)<br>print(type(numbers))<br>print(result, sumNum)<br><br>''' 4.4 使用列表的一部分 --=-=-=-=-=- 切片 '''<br># 你可以生成列表的任何子集,例如,如果你要提取列表的第2~4个元素,可将起始索引指定为 1,并将终止索引指定为 4:<br>players = ['charles', 'martina', 'michael', 'florence', 'eli']<br>print(players[1:4])<br>print(players[2:])<br>print(players[:2])<br>print(players[-3:]) # 倒数第三个到最后<br><br>''' P75 4.4.2 遍历切片'''<br>players = ['charles', 'martina', 'michael', 'florence', 'eli']<br>for i in players[:3]:<br> print(i)<br><br>''' 4.4.3 复制列表 '''<br>my_foods = ['pizza', 'falafel', 'carrot cake']<br># friend_foods = my_foods[:]<br># VS<br>friend_foods = my_foods # 并非把副本存储到 friend_foods<br>my_foods.append('cannoli')<br>print(friend_foods)<br><br>'''<br>列表总结:<br>列表非常适合用于存储在程序运行期间可能变化的数据集。列表是可以修改的,这对处理网<br>站的用户列表或游戏中的角色列表至关重要。<br>'''<br># In[2]<br>"""========4.5 元组========="""<br># 不可变的列表被称为元组<br>''' 4.5.1 定义元组 '''<br>dimensions = (200, 50)<br>print(dimensions[0])<br>print(dimensions[1])<br># dimensions[0] = 250 # TypeError: 'tuple' object does not support item assignment<br><br>''' 4.5.3 修改元组变量 '''<br>dimensions = (200, 50)<br>dimensions = (20, 20, "123", 10)<br>print(dimensions)
复制代码 Chapter_5_if语句
- # In[1] 5.2.2 检查是否相等时不考虑大小写<br>var = 'Audi'<br>print(var.lower() == 'audi')<br>print(var) # 函数 lower() 不会修改存储在变量car中的值<br><br># In[2] 5.2.3 检查是否不相等 5.2.4 比较数字 5.2.5 检查多个条件<br>age_1 = 10<br>age_2 = 12<br>if age_1 > 10 and age_2 > 10:<br> print('都大于10岁')<br>else:<br> if age_1 >= 10:<br> print('age_1 大于等于10')<br> if age_2 >= 10:<br> print('age_2 大于等于10')<br><br># In[3] 5.2.6 检查特定值是否包含在列表中 5.2.7 检查特定值是否不包含在列表中<br>requested_toppings = ['mushrooms', 'onions', 'pineapple']<br>print('onions' in requested_toppings)<br>print('onions' not in requested_toppings)<br><br># In[3] 5.2.8 布尔表达式 5.3.3 if-elif-else 结构<br>age = int(input('请输入你的年龄查询票价:'))<br>if age <= 0:<br> print("别闹,你不是人!")<br>elif age < 7:<br> print("你还小,不需要钱")<br>elif age <= 18:<br> print("你还是学生,只要 5 元")<br>else:<br> print('你不小了,成人票:58元')<br><br>
复制代码 - # In[1] 6.2.2 添加键—值对<br>'''<br>字典是一种动态结构,可随时在其中添加键—值对。要添加键—值对,可依次指定字典名、用<br>方括号括起的键和相关联的值。<br>'''<br>alien = {'color': 'green', 'points': 5}<br>print(alien)<br>alien['x_pos'] = 10 # 添加<br>print(alien)<br>alien['y_pos'] = 12<br>print(alien)<br>alien['color'] = 'red'<br>print(alien)<br><br># In[2]<br>alien = {}<br>print(type(alien))<br><br># In[3]<br>alien = {'color': 'green', 'points': 5}<br>print(alien['color'])<br>del alien['color']<br>print(alien)<br><br># In[4] 6.2.6 由类似对象组成的字典<br>favorite_languages = {<br> 'jen': 'python',<br> 'sarah': 'c',<br> 'edward': 'ruby',<br> 'phil': 'python',<br>}<br><br># In[5] 6.3 遍历字典 多种遍历字典的方式:可遍历字典的所有键—值对、键或值。<br>user_0 = {<br> 'username': 'efermi',<br> 'first': 'enrico',<br> 'last': 'fermi',<br>}<br>print(str(user_0.items()))<br># np.savetxt("dict.txt",str(a),fmt='%s')<br>for key, value in user_0.items():<br> print("\nKey:", key)<br> print("Value:", value)<br>'''注意,即便遍历字典时,键—值对的返回顺序也与存储顺序不同。Python不关心键—值对的存储顺序,而只跟踪键和值之间的关联关系。'''<br><br># In[6] 6.3.2 遍历字典中的所有键<br>favorite_languages = {<br> 'jen': 'python',<br> 'sarah': 'c',<br> 'edward': 'ruby',<br> 'phil': 'python',<br>}<br>for key in favorite_languages.keys():<br> print(key.title())<br># 等价于 || 以下的语句 显式与隐式功能相同<br>for key in favorite_languages:<br> print(key.title())<br><br># In[7] 6.3.3 按顺序遍历字典中的所有键<br>favorite_languages = {<br> 'jen': 'python',<br> 'sarah': 'c',<br> 'edward': 'ruby',<br> 'phil': 'python',<br>}<br>for name in sorted(favorite_languages.keys()): # 临时排序而已<br> print(name.title())<br>print(favorite_languages.keys())<br><br># In[8] 6.3.4 遍历字典中的所有值<br>favorite_languages = {<br> 'jen': 'python',<br> 'sarah': 'c',<br> 'edward': 'ruby',<br> 'phil': 'python',<br>}<br>for value in favorite_languages.values():<br> print(value.title())<br>print('------以上方法这种做法提取字典中所有的值,而没有考虑是否重复------')<br># 以上方法这种做法提取字典中所有的值,而没有考虑是否重复<br>for value in set(favorite_languages.values()):<br> print(value.title())<br><br># In[9]<br># '''6.4 嵌套 可以在列表中嵌套字典、在字典中嵌套列表甚至在字典中嵌套字典'''<br>alien_0 = {'color': 'green', 'points': 5}<br>alien_1 = {'color': 'red', 'points': 10}<br>alien_2 = {'color': 'blue', 'points': 15}<br>aliens = [alien_0, alien_1, alien_2]<br>for al in aliens:<br> print(al)<br><br>print("----改进变高级一点----")<br><br># 改进变高级一点<br>aliens = []<br>for alien_number in range(30):<br> new_alien = {'color': 'green', 'points': 5}<br> aliens.append(new_alien)<br>for alien in aliens[:5]:<br> print(alien)<br><br># In[10]<br># 例如,你如何描述顾客点的比萨呢?如果使用列表,只能存储要添加的比萨配料;但如果使用字典,就不仅可在其中包含配料列表,还可包含其他有关比萨的描述。<br>"""P114 6.4.2 在字典中存储列表"""<br>""" 嵌套 """
复制代码 - 第七章 用户输入和 while 循环<br>7.1 函数 input() 的工作原理<br>7.1.1 编写清晰的程序<br>message = input("请输入你的名字:")<br>print(f"你好!{message}!")<br>请输入你的名字:一叶知秋<br>你好!一叶知秋!<br>7.1.2 使用 int() 来获取数值输入<br>age = input("请输入你的年龄:")<br>age = int(age)<br>if age >=18:<br> print("你已经成年了!")<br>elif age <18:<br> print("你还未成年!") <br>请输入你的年龄:18<br>你已经成年了!<br>7.1.3 求模运算符<br>例如:求模运算可以判断 x 是否是奇数、偶数<br>x = input('请你输入一个整数:')<br>try:<br> x = int(x)<br> if x % 2 == 0:<br> print("偶数!")<br> else:<br> print("奇数!")<br>except:<br> print("你输入的不是整数!")<br>请你输入一个整数:20<br>偶数!<br>7.2 while 循环简介<br>7.2.1 使用while循环<br>7.2.2 让用户选择何时退出<br>7.2.3 使用标志<br>active = True<br>while active:<br> message = input("输入“退出”即可退出while!")<br> if message == '退出':<br> active = False<br> print('退出成功!')<br> else:<br> print(f"{message}")<br>输入“退出”即可退出while!不退出<br>不退出<br>输入“退出”即可退出while!退出<br>退出成功!<br>7.2.4 使用 break 退出循环<br>7.2.5 在循环中使用 continue<br>7.2.6 避免无限循环<br>7.3 使用while循环来处理列表和字典<br>为什么使用while而不是for,优点如下:<br>比如 for 循环列表很优秀,但是for 循环时候不应该修改列表<br>要在遍历列表的同时修改列表,可以使用 while<br>7.3.1 在列表之间移动元素<br>假设有一个列表,其中包含新注册但还未验证的网站用户;<br><br>问:验证这些用户后,如何将他们移到另一个已验证用户列表中呢?<br><br>答:一种办法是使用一个while循环,在验证用户的同时将其从未验证用户列表中提取出来, 再将其加入到另一个已验证用户列表中。<br><br>代码可能类似于下面这样:<br><br>unconfirmed_users = ['alice','brian']<br>confirmed_users = []<br>while unconfirmed_users:<br> current_user = unconfirmed_users.pop()<br> print(f"{current_user}的验证过程,通过!")<br> confirmed_users.append(current_user)<br>print("验证通过的人名:")<br>for confirmed_user in confirmed_users:<br> print(confirmed_user.title())<br>brian的验证过程,通过!<br>alice的验证过程,通过!<br>验证通过的人名:<br>Brian<br>Alice<br>max(list(map(int,input("输入一系列整数:").split(" "))))<br>输入一系列整数:12<br>12<br><br>
复制代码 第十章 文件和异常
10.1 从文件中读取数据 .............................. 162
10.1.1 读取整个文件 ........................ 162
with open('pi_digits.txt') as file_object:
contents = file_object.read()
print(contents)
使用文件步骤:
1、打开文件 open()
help(open)
open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)
Open file and return a stream. Raise OSError upon failure.
小贴士:关键字 with 在不再需要访问文件后将其关闭,你只管打开文件,并在需要时使用它,Python自会在合适的时候自动将其关闭。
为什么不使用 open() and close() ? 因为如果程序存在bug,导致close()语句未执行,文件将不会关闭。未妥善地关闭文件可能会导致数据丢失或受损
2、读取文件 read(),返回一个长长的字符串存入contents中
小贴士:【但是我并未遇到!】相比于原始文件,该输出唯一不同的地方是末尾多了一个空行。为何会多出这个空行呢?因为read()到达文件末尾时返回一个空字符串,而将这个空字符串显示出来时就是一个空行。要删除多出来的空行,可在print语句中使用rstrip()
10.1.2 文件路径 ................................ 164
当前情况:
程序文件在:python_work 文件夹
要读取的文件在:python_work 下 text_files 文件夹
∵ 由于文件夹text_files位于文件夹 python_work 中,因此可使用相对文件路径来打开该文件夹中的文件
小贴士:
1、相对路径 vs 绝对路径,在使用绝对路径时候往往较长,存入变量后再进行传递给open()
2、在Windows系统中,在文件路径中使用反斜杠(\)而不是斜杠(/),但是在程序中需要使用 "/",如下:
10.1.2 文件路径
with open('text_files/pi_digits.txt') as file_object:
contents = file_object.read()
print(contents.rstrip())
10.1.3 逐行读取 ................................ 165
业务需求/应用场景:
- def greet_user():
- """显示简单的问候语"""
- print("hello")
复制代码 10.1.4 创建一个包含文件各行内容的列表.................................... 166
10.1.5 使用文件的内容 ..................... 166
10.1.6 包含一百万位的大型文件 ..... 168
10.1.7 圆周率值中包含你的生日吗 ........................................ 168
10.2 写入文件 .............................................. 169
10.2.1 写入空文件 ............................ 170
10.2.2 写入多行 ................................ 170
10.2.3 附加到文件 ............................ 171
10.3 异常 ..................................................... 172
10.3.1 处理 ZeroDivisionError异常 ........................................ 172
10.3.2 使用 try-except 代码块 ......... 173
10.3.3 使用异常避免崩溃 ................. 173
10.3.4 else 代码块 ............................ 174
10.3.5 处理 FileNotFoundError异常 ........................................ 175
10.3.6 分析文本 ................................ 176
10.3.7 使用多个文件 ........................ 177
10.3.8 失败时一声不吭 ..................... 178
10.3.9 决定报告哪些错误 ................. 179
10.4 存储数据 .............................................. 180
10.4.1 使用 json.dump()和 json.load() ..................................... 180
10.4.2 保存和读取用户生成的数据 ........................................ 181
10.4.3 重构 ........................................ 183
10.5 小结 ..................................................... 18
来源:https://www.cnblogs.com/IT-QiuYe/p/17008750.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作! |
|