一、实验目的

1、掌握文件的打开、关闭操作的使用步骤;
2、掌握文件读写的相关使用步骤;
3、掌握文件删除及重命名的相关使用步骤;
4、了解扩展库openpyxl的安装与使用
5、了解扩展库 python-docx 的安装与使用

二、实验环境

装有Python运行环境、Pycharm平台的PC电脑一台

三、实验内容

1、完成书中P164页的案例“学生管理系统”,并运行查看结果;

2、从键盘输入一个字符串,将小写字母全部转换成大写字母,然后输出到一个磁盘文件”test”中保存。
image.png
3、有两个磁盘文件A和B,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列), 输出到一个新文件C中。

  1. """
  2. 3、有两个磁盘文件A和B,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列), 输出到一个新文件C中。
  3. """
  4. fp1 = open('A.txt', 'w')
  5. a_str1 = input("请写入字符串:")
  6. fp1.write(a_str1)
  7. fp1.close()
  8. fpr1 = open('A.txt', 'r')
  9. a_str11 = fpr1.read()
  10. print("A.txt:",a_str11)
  11. fpr1.close()
  12. fp2 = open('B.txt', 'w')
  13. a_str2 = input("请写入字符串:")
  14. fp2.write(a_str2)
  15. fp2.close()
  16. fpr2 = open('B.txt', 'r')
  17. a_str22 = fpr2.read()
  18. print("B.txt:",a_str22)
  19. fpr2.close()
  20. fp = open('C.txt', 'w')
  21. fp_str = str(a_str1 + a_str2)
  22. fp.write(fp_str)
  23. fp.close()
  24. fpr3 = open('B.txt', 'r')
  25. a_str33 = fpr3.read()
  26. print("C.txt:",a_str33)
  27. fpr3.close()

image.png
4、编写程序,生成 200 个人的模拟信息,包括姓名、性别、年龄、电话号码、家庭住址、电子邮箱地址,把生成的信息写入文本文件,每行存放一个人的信息,最后再读取生成的文本文件并输出其中的信息

  1. """
  2. 4、编写程序,生成 200 个人的模拟信息,
  3. 包括姓名、性别、年龄、电话号码、家庭住址、电子邮箱地址,
  4. 把生成的信息写入文本文件,每行存放一个人的信息,
  5. 最后再读取生成的文本文件并输出其中的信息
  6. """
  7. import random
  8. import string
  9. #常见的姓
  10. n1="王 李 张 刘 陈 杨 黄 赵 吴 周 徐 孙 马 朱 胡 郭 何 高 林 罗 郑 梁 谢 宋 唐 许 " \
  11. "韩 冯 邓 曹 彭 曾 萧 田 董 潘 袁 于 蒋 蔡 余 杜 叶 程 苏 魏 吕 丁 任 沈 姚 卢 " \
  12. "姜 崔 钟 谭 陆 汪 范 金 石 廖 贾 夏 韦 傅 方 白 邹 孟 熊 秦 邱 江 尹 薛 阎 段 " \
  13. "雷 侯 龙 史 陶 黎 贺 顾 毛 郝 龚 邵 万 钱 严 覃 武 戴 莫 孔 向 汤 "
  14. #字
  15. name2="\u7684\u4e00\u662f\u4e86\u6211\u4e0d\u4eba\u5728\u4ed6\u6709\u8fd9\u4e2a\u4e0a\u4eec\u6765"\
  16. "\u5230\u65f6\u5927\u5730\u4e3a\u5b50\u4e2d\u4f60\u8bf4\u751f\u56fd\u5e74\u7740\u5c31\u90a3"\
  17. "\u548c\u8981\u5979\u51fa\u4e5f\u5f97\u91cc\u540e\u81ea\u4ee5\u4f1a\u5bb6\u53ef\u4e0b\u800c"\
  18. "\u8fc7\u5929\u53bb\u80fd\u5bf9\u5c0f\u591a\u7136\u4e8e\u5fc3\u5b66\u4e48\u4e4b\u90fd\u597d"\
  19. "\u770b\u8d77\u53d1\u5f53\u6ca1\u6210\u53ea\u5982\u4e8b\u628a\u8fd8\u7528\u7b2c\u6837\u9053"\
  20. "\u60f3\u4f5c\u79cd\u5f00\u7f8e\u603b\u4ece\u65e0\u60c5\u5df1\u9762\u6700\u5973\u4f46\u73b0"\
  21. "\u524d\u4e9b\u6240\u540c\u65e5\u624b\u53c8\u884c\u610f\u52a8\u65b9\u671f\u5b83\u5934\u7ecf"\
  22. "\u957f\u513f\u56de\u4f4d\u5206\u7231\u8001\u56e0\u5f88\u7ed9\u540d\u6cd5\u95f4\u65af\u77e5"\
  23. "\u4e16\u4ec0\u4e24\u6b21\u4f7f\u8eab\u8005\u88ab\u9ad8\u5df2\u4eb2\u5176\u8fdb\u6b64\u8bdd"\
  24. "\u5e38\u4e0e\u6d3b\u6b63\u611f\u89c1\u660e\u95ee\u529b\u7406\u5c14\u70b9\u6587\u51e0\u5b9a"\
  25. "\u672c\u516c\u7279\u505a\u5916\u5b69\u76f8\u897f\u679c\u8d70\u5c06\u6708\u5341\u5b9e\u5411"\
  26. "\u58f0\u8f66\u5168\u4fe1\u91cd\u4e09\u673a\u5de5\u7269\u6c14\u6bcf\u5e76\u522b\u771f\u6253"\
  27. "\u592a\u65b0\u6bd4\u624d\u4fbf\u592b\u518d\u4e66\u90e8\u6c34\u50cf\u773c\u7b49\u4f53\u5374"\
  28. "\u52a0\u7535\u4e3b\u754c\u95e8\u5229\u6d77\u53d7\u542c\u8868\u5fb7\u5c11\u514b\u4ee3\u5458"\
  29. "\u8bb8\u7a1c\u5148\u53e3\u7531\u6b7b\u5b89\u5199\u6027\u9a6c\u5149\u767d\u6216\u4f4f\u96be"\
  30. "\u671b\u6559\u547d\u82b1\u7ed3\u4e50\u8272\u66f4\u62c9\u4e1c\u795e\u8bb0\u5904\u8ba9\u6bcd"\
  31. "\u7236\u5e94\u76f4\u5b57\u573a\u5e73\u62a5\u53cb\u5173\u653e\u81f3\u5f20\u8ba4\u63a5\u544a"\
  32. "\u5165\u7b11\u5185\u82f1\u519b\u5019\u6c11\u5c81\u5f80\u4f55\u5ea6\u5c71\u89c9\u8def\u5e26"\
  33. "\u4e07\u7537\u8fb9\u98ce\u89e3\u53eb\u4efb\u91d1\u5feb\u539f\u5403\u5988\u53d8\u901a\u5e08"\
  34. "\u7acb\u8c61\u6570\u56db\u5931\u6ee1\u6218\u8fdc\u683c\u58eb\u97f3\u8f7b\u76ee\u6761\u5462"\
  35. "\u75c5\u59cb\u8fbe\u6df1\u5b8c\u4eca\u63d0\u6c42\u6e05\u738b\u5316\u7a7a\u4e1a\u601d\u5207"\
  36. "\u600e\u975e\u627e\u7247\u7f57\u94b1\u7d36\u5417\u8bed\u5143\u559c\u66fe\u79bb\u98de\u79d1"\
  37. "\u8a00\u5e72\u6d41\u6b22\u7ea6\u5404\u5373\u6307\u5408\u53cd\u9898\u5fc5\u8be5\u8bba\u4ea4"\
  38. "\u7ec8\u6797\u8bf7\u533b\u665a\u5236\u7403\u51b3\u7aa2\u4f20\u753b\u4fdd\u8bfb\u8fd0\u53ca"\
  39. "\u5219\u623f\u65e9\u9662\u91cf\u82e6\u706b\u5e03\u54c1\u8fd1\u5750\u4ea7\u7b54\u661f\u7cbe"\
  40. "\u89c6\u4e94\u8fde\u53f8\u5df4\u5947\u7ba1\u7c7b\u672a\u670b\u4e14\u5a5a\u53f0\u591c\u9752"\
  41. "\u5317\u961f\u4e45\u4e4e\u8d8a\u89c2\u843d\u5c3d\u5f62\u5f71\u7ea2\u7238\u767e\u4ee4\u5468"\
  42. "\u5427\u8bc6\u6b65\u5e0c\u4e9a\u672f\u7559\u5e02\u534a\u70ed\u9001\u5174\u9020\u8c08\u5bb9"\
  43. "\u6781\u968f\u6f14\u6536\u9996\u6839\u8bb2\u6574\u5f0f\u53d6\u7167\u529e\u5f3a\u77f3\u53e4"\
  44. "\u534e\u8ae3\u62ff\u8ba1\u60a8\u88c5\u4f3c\u8db3\u53cc\u59bb\u5c3c\u8f6c\u8bc9\u7c73\u79f0"\
  45. "\u4e3d\u5ba2\u5357\u9886\u8282\u8863\u7ad9\u9ed1\u523b\u7edf\u65ad\u798f\u57ce\u6545\u5386"\
  46. "\u60ca\u8138\u9009\u5305\u7d27\u4e89\u53e6\u5efa\u7ef4\u7edd\u6811\u7cfb\u4f24\u793a\u613f"\
  47. "\u6301\u5343\u53f2\u8c01\u51c6\u8054\u5987\u7eaa\u57fa\u4e70\u5fd7\u9759\u963f\u8bd7\u72ec"\
  48. "\u590d\u75db\u6d88\u793e\u7b97\u4e49\u7adf\u786e\u9152\u9700\u5355\u6cbb\u5361\u5e78\u5170"\
  49. "\u5ff5\u4e3e\u4ec5\u949f\u6015\u5171\u6bdb\u53e5\u606f\u529f\u5b98\u5f85\u7a76\u8ddf\u7a7f"
  50. name1=n1.split(" ")#从网上复制粘贴下来有空格所以用了spilt()将空格给去掉了
  51. #姓名
  52. def getName():
  53. name=random.choice(name1)#从name1中选取一个当姓
  54. #姓名长度可能位2,3,4
  55. for i in range(random.choice([2,3,4])-1):#因为前边有一个姓了所以-1
  56. name=name+random.choice(name2)
  57. return name
  58. #性别
  59. def sex():
  60. return random.choice(["男","女"])#从男女中随机选一个
  61. #电话号码,手机号码是一个字符串,11位
  62. def phoneNumber():
  63. number="1"#开头数字是1
  64. for i in range(10):#剩下的10
  65. number=number+random.choice(string.digits)#string.digits 返回'0123456789'
  66. return number
  67. #年龄
  68. def Age():
  69. return str(random.randint(1,85))#年龄在1-85岁之间
  70. #邮箱
  71. def Email():
  72. email=''
  73. #邮箱的结尾
  74. ending = ["@qq.com", "@163.com", "@126.com", "@hotmail.com", "@gmail.com"]
  75. #随机选择邮箱的长度
  76. for i in range(random.randint(6,12)):
  77. email=email+random.choice(string.ascii_letters+string.digits)
  78. email=email+random.choice(ending)
  79. return email
  80. #将信息输入到文本之中去
  81. def Input(n):
  82. f=open("demo04.txt","w")
  83. for i in range(n):#n表示多少条数据
  84. message=list(getName()+" "+sex()+" "+Age()+" "+phoneNumber()+' '+Email()+"\n")
  85. f.writelines(message) #利用writelines写入数据
  86. # f.writelines("\n") #进行换行
  87. f.close()
  88. #读取文本中的信息
  89. def read():
  90. f=open("demo04.txt","r")
  91. for line in f: #逐行读内容
  92. print(line)
  93. f.close()
  94. n=200
  95. Input(n)
  96. read()
  1. C:\Users\23046\AppData\Local\Programs\Python\Python38\python.exe D:\Study\Python\python_test\demo05\demo04.py
  2. 姜花分生 52 14454110897 e8HzShXZz@126.com
  3. 朱传精 9 10105531960 7XRaylHr6@163.com
  4. 高加由看 4 10029098070 nDm50jXTlZ@hotmail.com
  5. 许她千 18 15360277706 XjC3reX@qq.com
  6. 金演兰 59 14572419622 a120NRos4IYA@hotmail.com
  7. 钱社决吃 23 19168679632 WFxLtd@gmail.com
  8. 丁断格 35 14786914658 0cmgyhN@hotmail.com
  9. 覃官北 59 14507577693 UX1vJKY@hotmail.com
  10. 范每学管 2 10377883262 UGB6xGzVfmSB@126.com
  11. 郝住原 43 15509944052 HUzUhY1pIxqS@qq.com
  12. 段西 17 12013628185 o0C8keW7es@gmail.com
  13. 汤算四风 82 19910884546 TwJs10lTNuXb@126.com
  14. 金福元 63 11788718562 kWFM31Oj6aR@126.com
  15. 罗需社 25 11692045639 Cuh2REj@126.com
  16. 贾入 40 13341899223 EzUuaKQV@gmail.com
  17. 田制点么 81 16504297776 6EgzmnJHVH@qq.com
  18. 戴则 59 16414180806 Octy5Bpn@hotmail.com
  19. 钟需諣近 82 16255056547 HL3AOhobHo@gmail.com
  20. 江小 80 17734550864 T626hD@163.com
  21. 邓孩穿 85 13018750936 9I21HK@qq.com
  22. 徐口 53 17355037271 mWCv7aY8@gmail.com
  23. 卢事答话 36 17846937199 5mL38v2hV2@gmail.com
  24. 魏久转于 68 12408835257 iKH7gVzWblbr@126.com
  25. 贺部 25 17355209750 qqVTrXStIEns@gmail.com
  26. 曹就中 32 17168310008 tm5NFnPH@hotmail.com
  27. 曾司及西 10 17349120177 qky4AMHMTS7@163.com
  28. 武些公至 50 15383351825 Yf1px0NKZ9@126.com
  29. 吕准火头 42 19954596719 OXtA9Dqaa@hotmail.com
  30. 朱球名度 77 12264472292 wNWFgx3D@126.com
  31. 邓队电 13 11604158824 5ehWUoGlI@hotmail.com
  32. 郭得她 60 11845428838 7pVwBm0QAPj@hotmail.com
  33. 雷音要 59 14138635371 Sl9W9yjqT@qq.com
  34. 戴事只 64 11290469446 WvZfNkkg2M9@126.com
  35. 曾基切 38 13663951900 q1kpDuVx32@163.com
  36. 莫好通社 63 12536177156 7hH9zCCl@gmail.com
  37. 覃然近 60 13934750101 LjtJSljeY@qq.com
  38. 杨气数 62 18285823713 yYprNaRmw@126.com
  39. 邹罗 33 13102606172 MDMc8U@gmail.com
  40. 顾候 50 15118478071 uHMmDuqdtr@qq.com
  41. 郭些 23 12536421077 Perbt1f8szqH@qq.com
  42. 宋称利 46 10448050870 OBjQija6vZe@qq.com
  43. 魏似 34 16416473790 z7MAniXi@126.com
  44. 史痛 44 19368903538 CH7xG1@gmail.com
  45. 谭深听 2 15360382769 WidnNTzOYh@hotmail.com
  46. 徐手酒德 85 15808054222 aGbRtbsdK@qq.com
  47. 韦送欢 68 16739437641 c3Z2Rx@hotmail.com
  48. 苏个会 18 15083795984 VTvmnqB3@gmail.com
  49. 于惊 74 18726839014 Z1LJiOb@hotmail.com
  50. 蔡各始志 52 13098151916 PdbEP9aF@163.com
  51. 吴流 71 15766553483 d1lL2geSYO@163.com
  52. 秦失作亲 19 14708000871 4oClTj3npu3@126.com
  53. 赵候 46 10949949351 lBPHNpw@hotmail.com
  54. 袁妈路取 21 16432636454 Y0PEYU@hotmail.com
  55. 卢的 16 17867773948 IL40ltj@126.com
  56. 邱读愿 35 18606375289 qV8gMdQRyly@gmail.com
  57. 韩做发诉 13 14834134477 HIzo2k@gmail.com
  58. 徐传 13 16449752682 wj1tO74M6i@163.com
  59. 刘义其世 73 17431931236 ZlZgPRBG20Fc@163.com
  60. 金话望 3 17347776478 vn6foYnS@163.com
  61. 陈定 70 11109221434 sGB7Xa@hotmail.com
  62. 沈周识 60 13873647285 aJXAlX@126.com
  63. 韩火很军 76 19359478204 ALFf3qW5@gmail.com
  64. 潘爸力 54 11260475506 OmGU55Mnj@gmail.com
  65. 田准功开 10 19493105231 ZWzv0r5n@gmail.com
  66. 冯息关 66 13053015943 wil6GcXMc@qq.com
  67. 石似期 19 17355894742 33p1sJnoW7q@hotmail.com
  68. 魏痛 9 12072483011 MKkRbfC0mxFT@hotmail.com
  69. 余三发 24 12220314685 8TGbNEW2@qq.com
  70. 程决清 10 18932045724 IduGLUWTxZ4@hotmail.com
  71. 许此 35 13848893656 KvkymyB6E@163.com
  72. 陈父告 53 10857540589 0DKNcI8U4@gmail.com
  73. 白及直布 23 10884744431 lYYCVR8qCwx4@hotmail.com
  74. 任分几保 77 19009988133 9noD3OCxVkZ@163.com
  75. 陈风 11 13961663351 oE1vmc@163.com
  76. 朱大任活 81 18720434591 REnjXAZr@126.com
  77. 傅谈吗 64 12941317137 CR1A3pzl2@hotmail.com
  78. 胡吧毛 63 18540360661 Auq6gr6@163.com
  79. 何何特日 81 14140453240 amCFdNha9D9@hotmail.com
  80. 李单 36 16743934106 yHl8PtClpw7@gmail.com
  81. 曾难风百 67 18168309992 zczTYf3@qq.com
  82. 秦两士 41 13110340451 XGVhspftJa8c@hotmail.com
  83. 顾任身北 37 15054197941 GO4shCLhOT@hotmail.com
  84. 江动何也 70 19072428907 Ap5wCBNI2OjT@qq.com
  85. 谭没 2 17419603903 wFQTkEfPOn@163.com
  86. 顾放 29 16160824844 na2FHCS@gmail.com
  87. 胡第仅应 7 19391462007 CpYIXhtPh@hotmail.com
  88. 白后球是 5 11393429557 BlH2j8EC@gmail.com
  89. 罗与生己 59 11213566214 h783qW4@126.com
  90. 陈制日条 33 15234806798 MW7lfkmhmyX@gmail.com
  91. 余容 28 15734600586 sW4MP1zyV@163.com
  92. 梁亲官 38 12199615352 zHqdCwR4f2@gmail.com
  93. 万本 42 19393760674 TuR90B3ttVF@126.com
  94. 董气运 71 11974842971 4YQRVZ8@hotmail.com
  95. 廖即 71 11835820437 XCd0gnDOyZUZ@qq.com
  96. 覃口该转 65 10287307424 dKDDuYh@163.com
  97. 陆苦无观 22 18900274622 8n2zgvB@hotmail.com
  98. 吕演独双 15 18375485889 BoiZVi18KgF@gmail.com
  99. 秦球争 44 10310726489 3fIUFTsu@163.com
  100. 彭另绝 67 14059405327 RlxZoIG@gmail.com
  101. 王早全 70 14881165532 YDK0HiikRj@gmail.com
  102. 钟争 10 14825994186 HrFsSPtO@hotmail.com
  103. 石点画 46 10130718021 hBTbZjVAkX@gmail.com
  104. 叶尔 60 16875912985 lkqUK6@gmail.com
  105. 万通望 83 13081799610 sDTQkLbk@126.com
  106. 杜全 25 11831102106 T15jugNg@qq.com
  107. 林岁一看 10 12102138379 ninmCGK@gmail.com
  108. 彭同合 66 12096450139 j5gYfZkyY@163.com
  109. 尹它整 80 13053785989 W1eYw9cp4K9@qq.com
  110. 任包 21 13820290351 umuQj3e@163.com
  111. 韩等 41 19617114662 B8KX2R@163.com
  112. 卢法我 84 19546177976 XEmp60rxJ7E@126.com
  113. 胡战小 67 18109322843 uknaWcJ6C@gmail.com
  114. 尹而 17 12967402694 5vys4iAw75ed@163.com
  115. 廖论光从 66 15067304886 wVqzPgD3OG@hotmail.com
  116. 侯知车月 48 10670688394 QAkjah@qq.com
  117. 侯师希风 79 11944366887 jkdpYD@126.com
  118. 顾南 50 13612039532 BMIUAtnW6@hotmail.com
  119. 贾马穿 73 11613317134 KN3ZMDPt@qq.com
  120. 史头眼可 77 14810304537 BnISYJVBP@gmail.com
  121. 钟可 7 12748619928 3rdw9TSfTsHA@126.com
  122. 戴才 48 19882165615 kkHua9TLx@gmail.com
  123. 史由 82 16135770678 slrmiWz@qq.com
  124. 曹收 44 16612386516 IYOIHC8wI@gmail.com
  125. 邹人 79 16291127167 mfSZMT3tCSw@gmail.com
  126. 王不实再 54 10426748415 YiIGaR0@hotmail.com
  127. 陈息 18 13667836315 agZcl7@126.com
  128. 魏些 7 14510650538 FJ6pEOwdJsg@gmail.com
  129. 莫早科海 29 14163256163 GlEabm9tHOmj@gmail.com
  130. 徐静句 42 15695649675 LIej3oVp@126.com
  131. 叶她远望 59 15017676826 LPntIYU@hotmail.com
  132. 钟米候 77 12776407746 2LhxaFlCUx@qq.com
  133. 魏至华斯 61 13264619181 a5t05gcyyX88@qq.com
  134. 段房 31 10688134513 8ZTy09Xl@163.com
  135. 龚最朋 41 11052680758 hc2JPpY@gmail.com
  136. 潘且讲 1 18828405162 j47jjjf@163.com
  137. 黎加随带 18 15193054342 FBFLAwVqC@163.com
  138. 江刻物无 18 19886980309 GkunZ3e9dpuR@126.com
  139. 薛眼 19 16106514450 9tCYrZ@hotmail.com
  140. 万格领何 73 17531914375 jzbj31m@hotmail.com
  141. 蔡候开第 2 18597224819 HxI4CfqX8@qq.com
  142. 曹象回则 27 16545598204 a2W39WBr@qq.com
  143. 杜定山 1 13938773207 QPTcfVE@gmail.com
  144. 程果球 55 13177659937 I2enqpjFqcBV@163.com
  145. 马活被仅 44 19852931950 fJ5e8r8fp@hotmail.com
  146. 邓产 24 11712592915 dqg2ubNESb@126.com
  147. 孔类学青 32 17650242862 H2zORi@gmail.com
  148. 金流定很 69 10620434279 CC66qyC3KC7t@gmail.com
  149. 邹行热 44 10080158347 rqjN2zG@qq.com
  150. 田精情 6 15160802419 ISaiUF4pcY7@qq.com
  151. 魏就紧 4 10297253300 lEEDkpr2@163.com
  152. 周也 7 15887309362 e9lrjc0@qq.com
  153. 邹流道可 17 17088015193 lZb9WCSSp3Ob@hotmail.com
  154. 韩容业 45 19057333750 HaSZ3XHOo5@qq.com
  155. 曹处你最 29 16567428349 R27JJfRGP83i@gmail.com
  156. 曾则起 57 18077140287 L3RUCf6a@qq.com
  157. 雷公 65 19168636483 OpvBcOMl@163.com
  158. 邓火 22 19443005664 0nSkPb1b@qq.com
  159. 黄欢历 75 14144076236 Nh7CIy0KuzSj@163.com
  160. 王化量 81 18887602943 QD1v95@gmail.com
  161. 莫诉称精 68 16365765373 xODCohMTt3@163.com
  162. 邵妻 24 16477767408 X93q9CW@163.com
  163. 朱十她 9 16475951590 LlsNWZH@163.com
  164. 夏岁 8 11323155821 0GZ1BT0ruUTJ@163.com
  165. 莫钟产 10 13926885153 KSn5oZKFc@163.com
  166. 陶制位 35 18058070586 DNBZJEWE@gmail.com
  167. 程请 42 19026097683 yFrbZxv6fgWJ@hotmail.com
  168. 陆近 73 18349124909 DtqgwPaOwoG@126.com
  169. 严妻神 18 11913473910 XsjCbkFB1f@hotmail.com
  170. 韩似 71 14533717609 hfi4LhEAbYnu@163.com
  171. 毛几妈达 63 11677260756 ts8EEKeB@163.com
  172. 夏认 15 19941049589 gobsWxeZO@126.com
  173. 廖作 29 17841241667 wiUOivIIja@gmail.com
  174. 马断 3 18284708286 vBnm8QbDiM7J@qq.com
  175. 赵息 66 11708271628 HUH9AG@163.com
  176. 林建 54 15591327606 qgI5scAF@qq.com
  177. 阎需言 60 13409875027 ZQiNMy@gmail.com
  178. 杜句 60 16841598258 4l62BtBZ3@qq.com
  179. 武些时最 1 12263387158 V55y2Gps3hJ@gmail.com
  180. 吴总 71 10141273219 jDMPRU@gmail.com
  181. 向金 79 13173971413 gWilaE@gmail.com
  182. 蒋古进约 31 11316084542 EPl3FS2d9Ra@gmail.com
  183. 赵答故市 51 15252654656 5yowZnqlZXA@qq.com
  184. 于夫今 79 19588343025 ggM6LZB@126.com
  185. 覃活三早 69 13780163858 u41NsCf67@126.com
  186. 杨常 45 10235158565 P8yXtqk3En29@gmail.com
  187. 尹认品制 83 12622097777 oBRj1wx@126.com
  188. 何和品 75 13956682478 ro45KMWO9E@hotmail.com
  189. 严钟 49 18802370371 PECXegtC1gV@gmail.com
  190. 石各所 20 13868433322 fi71jpmu3iKK@gmail.com
  191. 郑至象形 21 15249244798 xoLT7RyL@gmail.com
  192. 董走 21 10581184258 wRffOfd4Gkb@163.com
  193. 姜样晚 51 14841854441 qNAFCm@gmail.com
  194. 卢请口 14 10448378365 TwI6oXa@163.com
  195. 杜精 76 11457656539 J6oeP7mX5@163.com
  196. 陈晚比 5 15233618873 DZ1MowD0b@gmail.com
  197. 许主使成 43 13696800464 47Q7geKdjH@163.com
  198. 熊决毛 30 14951881707 7vaUKcTP0L7B@gmail.com
  199. 毛读 28 12187810996 WOTdbIF9@126.com
  200. 阎口 54 16959868707 J77s6kc1hS@hotmail.com
  201. 林照高比 62 17320139407 xNbfMc@gmail.com
  202. 进程已结束,退出代码0

5、编写一个程序 demo.py,要求运行该程序后,生成 demo_new.py 文件,其中内容与demo.py 一样,只是在每一行的后面加上行号。要求行号以#开始,并且所有行的#符号垂直对齐。
image.png

6、磁盘垃圾文件清理器
编写程序,实现磁盘垃圾文件清理功能。要求程序运行时,通过命令行参数指定要清理的文件夹,然后删除该文件夹及其子文件夹中所有扩展名为 tmp、log、obj、txt 以及大小为 0 的文件
image.png

7、Excel文件成绩处理
假设某学校所有课程每学期允许多次考试,学生可随时参加考试,系统自动将每次成绩添加到 Excel 文件(包含 3 列:姓名,课程,成绩)中,现期末要求统计所有学生每门课程的最高成绩。
编写程序,模拟生成若干同学的成绩并写入 Excel 文件,其中学生姓名和课程名称均
可重复,也就是允许出现同一门课程的多次成绩,最后统计所有学生每门课程的最高成绩,并写入新的 Excel 文件。

  1. #encoding=gbk
  2. """
  3. 7、Excel文件成绩处理
  4. 假设某学校所有课程每学期允许多次考试,学生可随时参加考试,系统自动将每次成绩添加到 Excel 文件(包含 3 列:姓名,课程,成绩)中,现期末要求统计所有学生每门课程的最高成绩。
  5. 编写程序,模拟生成若干同学的成绩并写入 Excel 文件,其中学生姓名和课程名称均
  6. 可重复,也就是允许出现同一门课程的多次成绩,最后统计所有学生每门课程的最高成绩,并写入新的 Excel 文件。
  7. pip install openpyxl
  8. """
  9. import openpyxl
  10. import random
  11. def autoGet(fileName):
  12. wb = openpyxl.Workbook()
  13. sheet = wb.active
  14. sheet.append(['姓名', '课程', '成绩'])
  15. first = tuple('王李张刘陈杨黄赵吴周徐孙马朱胡郭何高林罗郑梁谢宋唐许韩冯邓曹彭曾萧田董潘袁于蒋蔡余杜叶程苏魏吕丁任沈姚卢姜崔钟谭陆汪范金石廖贾夏韦傅方白邹孟熊秦邱江尹薛阎段雷侯龙史陶黎贺顾毛郝龚邵万钱严覃武戴莫孔向汤')
  16. middle = tuple('"\u7684\u4e00\u662f\u4e86\u6211\u4e0d\u4eba\u5728\u4ed6\u6709\u8fd9\u4e2a\u4e0a\u4eec\u6765"\
  17. "\u5230\u65f6\u5927\u5730\u4e3a\u5b50\u4e2d\u4f60\u8bf4\u751f\u56fd\u5e74\u7740\u5c31\u90a3"\
  18. "\u548c\u8981\u5979\u51fa\u4e5f\u5f97\u91cc\u540e\u81ea\u4ee5\u4f1a\u5bb6\u53ef\u4e0b\u800c"\
  19. "\u8fc7\u5929\u53bb\u80fd\u5bf9\u5c0f\u591a\u7136\u4e8e\u5fc3\u5b66\u4e48\u4e4b\u90fd\u597d"\
  20. "\u770b\u8d77\u53d1\u5f53\u6ca1\u6210\u53ea\u5982\u4e8b\u628a\u8fd8\u7528\u7b2c\u6837\u9053"\
  21. "\u60f3\u4f5c\u79cd\u5f00\u7f8e\u603b\u4ece\u65e0\u60c5\u5df1\u9762\u6700\u5973\u4f46\u73b0"\
  22. "\u524d\u4e9b\u6240\u540c\u65e5\u624b\u53c8\u884c\u610f\u52a8\u65b9\u671f\u5b83\u5934\u7ecf"\
  23. "\u957f\u513f\u56de\u4f4d\u5206\u7231\u8001\u56e0\u5f88\u7ed9\u540d\u6cd5\u95f4\u65af\u77e5"\
  24. "\u4e16\u4ec0\u4e24\u6b21\u4f7f\u8eab\u8005\u88ab\u9ad8\u5df2\u4eb2\u5176\u8fdb\u6b64\u8bdd"\
  25. "\u5e38\u4e0e\u6d3b\u6b63\u611f\u89c1\u660e\u95ee\u529b\u7406\u5c14\u70b9\u6587\u51e0\u5b9a"\
  26. "\u672c\u516c\u7279\u505a\u5916\u5b69\u76f8\u897f\u679c\u8d70\u5c06\u6708\u5341\u5b9e\u5411"\
  27. "\u58f0\u8f66\u5168\u4fe1\u91cd\u4e09\u673a\u5de5\u7269\u6c14\u6bcf\u5e76\u522b\u771f\u6253"\
  28. "\u592a\u65b0\u6bd4\u624d\u4fbf\u592b\u518d\u4e66\u90e8\u6c34\u50cf\u773c\u7b49\u4f53\u5374"\
  29. "\u52a0\u7535\u4e3b\u754c\u95e8\u5229\u6d77\u53d7\u542c\u8868\u5fb7\u5c11\u514b\u4ee3\u5458"\
  30. "\u8bb8\u7a1c\u5148\u53e3\u7531\u6b7b\u5b89\u5199\u6027\u9a6c\u5149\u767d\u6216\u4f4f\u96be"\
  31. "\u671b\u6559\u547d\u82b1\u7ed3\u4e50\u8272\u66f4\u62c9\u4e1c\u795e\u8bb0\u5904\u8ba9\u6bcd"\
  32. "\u7236\u5e94\u76f4\u5b57\u573a\u5e73\u62a5\u53cb\u5173\u653e\u81f3\u5f20\u8ba4\u63a5\u544a"\
  33. "\u5165\u7b11\u5185\u82f1\u519b\u5019\u6c11\u5c81\u5f80\u4f55\u5ea6\u5c71\u89c9\u8def\u5e26"\
  34. "\u4e07\u7537\u8fb9\u98ce\u89e3\u53eb\u4efb\u91d1\u5feb\u539f\u5403\u5988\u53d8\u901a\u5e08"\
  35. "\u7acb\u8c61\u6570\u56db\u5931\u6ee1\u6218\u8fdc\u683c\u58eb\u97f3\u8f7b\u76ee\u6761\u5462"\
  36. "\u75c5\u59cb\u8fbe\u6df1\u5b8c\u4eca\u63d0\u6c42\u6e05\u738b\u5316\u7a7a\u4e1a\u601d\u5207"\
  37. "\u600e\u975e\u627e\u7247\u7f57\u94b1\u7d36\u5417\u8bed\u5143\u559c\u66fe\u79bb\u98de\u79d1"\
  38. "\u8a00\u5e72\u6d41\u6b22\u7ea6\u5404\u5373\u6307\u5408\u53cd\u9898\u5fc5\u8be5\u8bba\u4ea4"\
  39. "\u7ec8\u6797\u8bf7\u533b\u665a\u5236\u7403\u51b3\u7aa2\u4f20\u753b\u4fdd\u8bfb\u8fd0\u53ca"\
  40. "\u5219\u623f\u65e9\u9662\u91cf\u82e6\u706b\u5e03\u54c1\u8fd1\u5750\u4ea7\u7b54\u661f\u7cbe"\
  41. "\u89c6\u4e94\u8fde\u53f8\u5df4\u5947\u7ba1\u7c7b\u672a\u670b\u4e14\u5a5a\u53f0\u591c\u9752"\
  42. "\u5317\u961f\u4e45\u4e4e\u8d8a\u89c2\u843d\u5c3d\u5f62\u5f71\u7ea2\u7238\u767e\u4ee4\u5468"\
  43. "\u5427\u8bc6\u6b65\u5e0c\u4e9a\u672f\u7559\u5e02\u534a\u70ed\u9001\u5174\u9020\u8c08\u5bb9"\
  44. "\u6781\u968f\u6f14\u6536\u9996\u6839\u8bb2\u6574\u5f0f\u53d6\u7167\u529e\u5f3a\u77f3\u53e4"\
  45. "\u534e\u8ae3\u62ff\u8ba1\u60a8\u88c5\u4f3c\u8db3\u53cc\u59bb\u5c3c\u8f6c\u8bc9\u7c73\u79f0"\
  46. "\u4e3d\u5ba2\u5357\u9886\u8282\u8863\u7ad9\u9ed1\u523b\u7edf\u65ad\u798f\u57ce\u6545\u5386"\
  47. "\u60ca\u8138\u9009\u5305\u7d27\u4e89\u53e6\u5efa\u7ef4\u7edd\u6811\u7cfb\u4f24\u793a\u613f"\
  48. "\u6301\u5343\u53f2\u8c01\u51c6\u8054\u5987\u7eaa\u57fa\u4e70\u5fd7\u9759\u963f\u8bd7\u72ec"\
  49. "\u590d\u75db\u6d88\u793e\u7b97\u4e49\u7adf\u786e\u9152\u9700\u5355\u6cbb\u5361\u5e78\u5170"\
  50. "\u5ff5\u4e3e\u4ec5\u949f\u6015\u5171\u6bdb\u53e5\u606f\u529f\u5b98\u5f85\u7a76\u8ddf\u7a7f"')
  51. last = tuple('"\u7684\u4e00\u662f\u4e86\u6211\u4e0d\u4eba\u5728\u4ed6\u6709\u8fd9\u4e2a\u4e0a\u4eec\u6765"\
  52. "\u5230\u65f6\u5927\u5730\u4e3a\u5b50\u4e2d\u4f60\u8bf4\u751f\u56fd\u5e74\u7740\u5c31\u90a3"\
  53. "\u548c\u8981\u5979\u51fa\u4e5f\u5f97\u91cc\u540e\u81ea\u4ee5\u4f1a\u5bb6\u53ef\u4e0b\u800c"\
  54. "\u8fc7\u5929\u53bb\u80fd\u5bf9\u5c0f\u591a\u7136\u4e8e\u5fc3\u5b66\u4e48\u4e4b\u90fd\u597d"\
  55. "\u770b\u8d77\u53d1\u5f53\u6ca1\u6210\u53ea\u5982\u4e8b\u628a\u8fd8\u7528\u7b2c\u6837\u9053"\
  56. "\u60f3\u4f5c\u79cd\u5f00\u7f8e\u603b\u4ece\u65e0\u60c5\u5df1\u9762\u6700\u5973\u4f46\u73b0"\
  57. "\u524d\u4e9b\u6240\u540c\u65e5\u624b\u53c8\u884c\u610f\u52a8\u65b9\u671f\u5b83\u5934\u7ecf"\
  58. "\u957f\u513f\u56de\u4f4d\u5206\u7231\u8001\u56e0\u5f88\u7ed9\u540d\u6cd5\u95f4\u65af\u77e5"\
  59. "\u4e16\u4ec0\u4e24\u6b21\u4f7f\u8eab\u8005\u88ab\u9ad8\u5df2\u4eb2\u5176\u8fdb\u6b64\u8bdd"\
  60. "\u5e38\u4e0e\u6d3b\u6b63\u611f\u89c1\u660e\u95ee\u529b\u7406\u5c14\u70b9\u6587\u51e0\u5b9a"\
  61. "\u672c\u516c\u7279\u505a\u5916\u5b69\u76f8\u897f\u679c\u8d70\u5c06\u6708\u5341\u5b9e\u5411"\
  62. "\u58f0\u8f66\u5168\u4fe1\u91cd\u4e09\u673a\u5de5\u7269\u6c14\u6bcf\u5e76\u522b\u771f\u6253"\
  63. "\u592a\u65b0\u6bd4\u624d\u4fbf\u592b\u518d\u4e66\u90e8\u6c34\u50cf\u773c\u7b49\u4f53\u5374"\
  64. "\u52a0\u7535\u4e3b\u754c\u95e8\u5229\u6d77\u53d7\u542c\u8868\u5fb7\u5c11\u514b\u4ee3\u5458"\
  65. "\u8bb8\u7a1c\u5148\u53e3\u7531\u6b7b\u5b89\u5199\u6027\u9a6c\u5149\u767d\u6216\u4f4f\u96be"\
  66. "\u671b\u6559\u547d\u82b1\u7ed3\u4e50\u8272\u66f4\u62c9\u4e1c\u795e\u8bb0\u5904\u8ba9\u6bcd"\
  67. "\u7236\u5e94\u76f4\u5b57\u573a\u5e73\u62a5\u53cb\u5173\u653e\u81f3\u5f20\u8ba4\u63a5\u544a"\
  68. "\u5165\u7b11\u5185\u82f1\u519b\u5019\u6c11\u5c81\u5f80\u4f55\u5ea6\u5c71\u89c9\u8def\u5e26"\
  69. "\u4e07\u7537\u8fb9\u98ce\u89e3\u53eb\u4efb\u91d1\u5feb\u539f\u5403\u5988\u53d8\u901a\u5e08"\
  70. "\u7acb\u8c61\u6570\u56db\u5931\u6ee1\u6218\u8fdc\u683c\u58eb\u97f3\u8f7b\u76ee\u6761\u5462"\
  71. "\u75c5\u59cb\u8fbe\u6df1\u5b8c\u4eca\u63d0\u6c42\u6e05\u738b\u5316\u7a7a\u4e1a\u601d\u5207"\
  72. "\u600e\u975e\u627e\u7247\u7f57\u94b1\u7d36\u5417\u8bed\u5143\u559c\u66fe\u79bb\u98de\u79d1"\
  73. "\u8a00\u5e72\u6d41\u6b22\u7ea6\u5404\u5373\u6307\u5408\u53cd\u9898\u5fc5\u8be5\u8bba\u4ea4"\
  74. "\u7ec8\u6797\u8bf7\u533b\u665a\u5236\u7403\u51b3\u7aa2\u4f20\u753b\u4fdd\u8bfb\u8fd0\u53ca"\
  75. "\u5219\u623f\u65e9\u9662\u91cf\u82e6\u706b\u5e03\u54c1\u8fd1\u5750\u4ea7\u7b54\u661f\u7cbe"\
  76. "\u89c6\u4e94\u8fde\u53f8\u5df4\u5947\u7ba1\u7c7b\u672a\u670b\u4e14\u5a5a\u53f0\u591c\u9752"\
  77. "\u5317\u961f\u4e45\u4e4e\u8d8a\u89c2\u843d\u5c3d\u5f62\u5f71\u7ea2\u7238\u767e\u4ee4\u5468"\
  78. "\u5427\u8bc6\u6b65\u5e0c\u4e9a\u672f\u7559\u5e02\u534a\u70ed\u9001\u5174\u9020\u8c08\u5bb9"\
  79. "\u6781\u968f\u6f14\u6536\u9996\u6839\u8bb2\u6574\u5f0f\u53d6\u7167\u529e\u5f3a\u77f3\u53e4"\
  80. "\u534e\u8ae3\u62ff\u8ba1\u60a8\u88c5\u4f3c\u8db3\u53cc\u59bb\u5c3c\u8f6c\u8bc9\u7c73\u79f0"\
  81. "\u4e3d\u5ba2\u5357\u9886\u8282\u8863\u7ad9\u9ed1\u523b\u7edf\u65ad\u798f\u57ce\u6545\u5386"\
  82. "\u60ca\u8138\u9009\u5305\u7d27\u4e89\u53e6\u5efa\u7ef4\u7edd\u6811\u7cfb\u4f24\u793a\u613f"\
  83. "\u6301\u5343\u53f2\u8c01\u51c6\u8054\u5987\u7eaa\u57fa\u4e70\u5fd7\u9759\u963f\u8bd7\u72ec"\
  84. "\u590d\u75db\u6d88\u793e\u7b97\u4e49\u7adf\u786e\u9152\u9700\u5355\u6cbb\u5361\u5e78\u5170"\
  85. "\u5ff5\u4e3e\u4ec5\u949f\u6015\u5171\u6bdb\u53e5\u606f\u529f\u5b98\u5f85\u7a76\u8ddf\u7a7f"')
  86. # 课程名称
  87. subjects = ('语文', '数学', '英语','化学')
  88. for i in range(2000):
  89. line = []
  90. r = random.randint(1, 100)
  91. name = random.choice(first)
  92. # 按一定概率生成只有两个字的中文名字
  93. if r > 50:
  94. name = name + random.choice(middle)
  95. name = name + random.choice(last)
  96. # 依次生成姓名、课程名称和成绩
  97. line.append(name)
  98. line.append(random.choice(subjects))
  99. line.append(random.randint(0, 100))
  100. sheet.append(line)
  101. # 保存数据,生成excel
  102. wb.save(fileName)
  103. def getMaxScore(oldfileName, newfilrName):
  104. wb = openpyxl.load_workbook(oldfileName)
  105. final_wb = openpyxl.Workbook() # 创建一个新的excel工作簿对象用来存储学生各科目最高成绩
  106. start_sheet = wb.active # 开始自动生成的文件
  107. final_sheet = final_wb.active
  108. final_sheet.title = '学生的各科成绩'
  109. final_sheet.append(['姓名', '课程', '最高分'])
  110. stuGrade = {} # 创建一个记录全校学生成绩的字典
  111. for i in range(2, start_sheet.max_row + 1):
  112. stuName = start_sheet['A' + str(i)].value # 获取学生名字
  113. lesName = start_sheet['B' + str(i)].value # 获取课程名
  114. score = start_sheet['C' + str(i)].value # 获取对应的分数
  115. # 判断stuGrade中是否存有该学生
  116. if stuName in stuGrade:
  117. stuGrade[stuName]
  118. else:
  119. stuGrade[stuName] = {}
  120. # 获取最大分数,先判断该学生下的成绩字典中是否存有这门课程
  121. if lesName in stuGrade[stuName]:
  122. if score > stuGrade[stuName][lesName]:
  123. stuGrade[stuName][lesName] = score
  124. else:
  125. stuGrade[stuName][lesName] = score
  126. for student in stuGrade:
  127. for lesson, score in stuGrade[student].items():
  128. final_sheet.append([student, lesson, score])
  129. final_wb.save(newfilrName)
  130. if __name__ == '__main__':
  131. oldfile = '全校学生成绩.xlsx'
  132. newfile = '学生每门课程的最高成绩.xlsx'
  133. autoGet(oldfile)
  134. getMaxScore(oldfile, newfile)

image.png
image.png

8、Word文件操作
编写程序,读取 Word 文件中的所有段落文本,然后输出其中所有红色的文本和加粗的文本以及同时具有这两种属性的文本

  1. #encoding=gbk
  2. """
  3. 8、Word文件操作
  4. 编写程序,读取 Word 文件中的所有段落文本,然后输出其中所有红色的文本和加粗的文本以及同时具有这两种属性的文本
  5. pip install python-docx -i http://pypi.douban.com/simple --trusted-host pypi.douban.com
  6. """
  7. from docx import Document
  8. from docx.shared import RGBColor
  9. boldText = []
  10. redText = []
  11. doc = Document('test.docx')
  12. for p in doc.paragraphs:
  13. for r in p.runs:
  14. # 加粗字体
  15. if r.bold:
  16. boldText.append(r.text)
  17. # 红色字体
  18. if r.font.color.rgb == RGBColor(255,0,0):
  19. redText.append(r.text)
  20. result = {'红色的文本': redText, '加粗的文本': boldText, '红色及加粗的文本': set(redText) & set(boldText)}
  21. # 输出结果
  22. for title in result.keys():
  23. print(title.center(30, '='))
  24. for text in result[title]:
  25. print(text)

image.png
image.png

心得体会

练习了python对文件的基本操作(word,Excel)