作业来源:https://edu.cnblogs.com/campus/gzcc/GZCC-16SE1/homework/2753

一.列表,元组,字典,集合分别如何增删改查及遍历。

  • 列表
# 列表的增加
ls =['Hello','Word','JS','OK','Good']
print("原始数据:",ls)
ls.append(12) # 在数组列表后面增加字符串“12”
print("增加后的数组为:",ls) # 列表的删除
del ls[1] # 删除数组的第二个元素,即下标为1的字符串
# ls.pop() # 删除列表最后一个元素
print("删除数组第二个元素后数组为:",ls) # 列表的修改
ls[1] = "修改" # 删除数组的第二个元素,即下标为1的字符串
print("修改数组第二个元素后数组为:",ls) # 列表的查询
ls.index('OK') # 查找“OK”字符串
print("打印字符串“OK”的下标:",ls.index('OK')) # 遍历列表
print("遍历列表:")
for i in ls:
print(i)

结果:

  • 元组
 # 元组
YZ = ('元','组','的','元','素','不','修','改')
YZ1 = ('的','!')
YZ2 = YZ + YZ1
del YZ # 删除元组
print("元组的遍历:")
for i in YZ2:
print("\t\t",i)

结果:

  • 字典
 # 字典
D = {'这':1,'是':2,'字':3,'典':4,'!':5}
D['这']=11 # 修改键“这”的值
del D['是'] # 删除键“是”
a = D['这'] # 查看键a的值
print("字典\n查看“这”的下标:",a)
# D.clear() # 删除字典中的所有条目
# 遍历输出列表
str(D) # 打印字典
for key in D:
print(key)

结果:

  • 集合
# 集合
aa = {1, 2, 3}
aa.add(4) # 增加
print(aa) aa.remove(2) # 删除
print(aa)
# 遍历打印
for i in aa:
print("\t\t",i)

结果:

二、总结列表,元组,字典,集合的联系与区别。参考以下几个方面:

  • 括号
  • 有序无序
  • 可变不可变
  • 重复不可重复
  • 存储与查找方式
 

列表

元组

字典

集合

名称

list

tuple

dict

set

初始化

[‘0’,’0’,’1’]

(‘0’,’0’,’1’)

{‘0’:1,’0’:2,’1’:3}

{1,2}或set([2,3])

是否有序

有序

有序

无序,自动正序

无序

可否重复

读写性

读写

只读

读写

读写

存储方式

键值对(键不可重复)

键(不可重复)

添加

append

只读

add

d[‘key’]=’value’

三、词频统计

1.下载一长篇小说,存成utf-8编码的文本文件 file

2.通过文件读取字符串 str

3.对文本进行预处理

4.分解提取单词 list

5.单词计数字典 set , dict

6.按词频排序 list.sort(key=lambda),turple

7.排除语法型词汇,代词、冠词、连词等无语义词

    • 自定义停用词表
    • 或用stops.txt

8.输出TOP(20)

9.可视化:词云

排序好的单词列表word保存成csv文件

import pandas as pd
# 打开小说
f = open(r'..\Lin\file_text\Sophies World.txt', 'r', encoding='utf8')
book = f.read()
f.close() book_symbol = ['\n', '\t', '?', '?', '!', "!"," '", "'", ' "', '"', '""', ',', ',', '.', '。','“','”',','] # 删除标点符号
for i in book_symbol:
book = book.replace(i, '') # 把所有的小写 以空格分隔开
book = book.lower().split() # 打开停用词
f = open(r'..\Lin\file_text\stops.txt', 'r', encoding='utf8')
stops = f.read()
f.close()
# 删除多余符号
stop_symbol = [" '", "'", ' "', '"', '\n']
for i in stop_symbol:
stops = stops.replace(i, '')
# 以逗号分隔
stops = stops.split(',')
word_dict = {} # 创建词典 # 去掉停用词
word_set = set(book) - set(stops) # 遍历计算词频
for i in word_set:
word_dict[i] = book.count(i) word_count = list(word_dict.items())
word_count.sort(key = lambda x:x[1], reverse = True)
pd.DataFrame(data=word_count[0:20]).to_csv('Sophies World.csv', encoding='utf-8')

结果:

菜鸟学IT之python3关于列表,元组,字典,集合浅认识!的更多相关文章

  1. python3笔记十八:python列表元组字典集合文件操作

    一:学习内容 列表元组字典集合文件操作 二:列表元组字典集合文件操作 代码: import pickle  #数据持久性模块 #封装的方法def OptionData(data,path):    # ...

  2. python中列表 元组 字典 集合的区别

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...

  3. **python中列表 元组 字典 集合

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...

  4. python_列表——元组——字典——集合

    列表——元组——字典——集合: 列表: # 一:基本使用# 1.用途:存放多个值 # 定义方式:[]内以逗号为分隔多个元素,列表内元素无类型限制# l=['a','b','c'] #l=list([' ...

  5. Python列表,元组,字典,集合详细操作

    菜鸟学Python第五天 数据类型常用操作及内置方法 列表(list) ======================================基本使用====================== ...

  6. python 中列表 元组 字典 集合的区别

    先看图片解释 (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计过去一周我们买过的东西,把这些东西列出来,就是清单.由于我们买一种东西可能不止一次,所以清单中是允许有重复 ...

  7. python的学习笔记01_4基础数据类型列表 元组 字典 集合 其他其他(for,enumerate,range)

    列表 定义:[]内以逗号分隔,按照索引,存放各种数据类型,每个位置代表一个元素 特性: 1.可存放多个值 2.可修改指定索引位置对应的值,可变 3.按照从左到右的顺序定义列表元素,下标从0开始顺序访问 ...

  8. Day 07 数据类型的内置方法[列表,元组,字典,集合]

    数据类型的内置方法 一:列表类型[list] 1.用途:多个爱好,多个名字,多个装备等等 2.定义:[]内以逗号分隔多个元素,可以是任意类型的值 3.存在一个值/多个值:多个值 4.有序or无序:有序 ...

  9. Python数据类型-布尔/数字/字符串/列表/元组/字典/集合

    代码 bol = True # 布尔 num = 100000000; # 数字 str = "fangbei"; # 字符串 str_cn = u"你好,方倍" ...

随机推荐

  1. python爬虫数据解析之BeautifulSoup

    BeautifulSoup是一个可以从HTML或者XML文件中提取数据的python库.它能够通过你喜欢的转换器实现惯用的文档导航,查找,修改文档的方式. BeautfulSoup是python爬虫三 ...

  2. 《深入理解Java虚拟机》-----第3章 垃圾收集器与内存分配策略

    Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的“高墙”,墙外面的人想进去,墙里面的人却想出来. 3.1 概述 说起垃圾收集(Garbage Collection,GC),大部分人都把这 ...

  3. 【Android Studio安装部署系列】十八、Android studio更换APP应用图标

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 Android Studio新建项目后会有一个默认图标,那么如何更换图标呢? 替换图标 这个方案不建议直接在已有项目上更换图标,建议 ...

  4. Java集合详解4:HashMap和HashTable

    今天我们来探索一下HashMap和HashTable机制与比较器的源码. 具体代码在我的GitHub中可以找到 https://github.com/h2pl/MyTech 喜欢的话麻烦star一下哈 ...

  5. JVM(六)为什么新生代有两个Survivor分区?

    本文会使用排除法的手段,来讲解新生代的区域划分,从而让读者能够更清晰的理解分代回收器的原理,在开始之前我们先来整体认识一下分代收集器. 分代收集器会把内存空间分为:老生代和新生代两个区域,而新生代又会 ...

  6. 展开隐形的翅膀,WPR003N补完篇

    在上一回合要搞刷机!从它的尸体上踏过去!钢板云路由!WPR003N复活!成功启动OPENWRT中,笔者成功的让一个4年前主流芯片搭上OS的快船,留下一段佳话. 今天看着抽屉里的WPR003N,回忆它之 ...

  7. asp.net后台管理系统-登陆模块-是否自动登陆

    FormsAuthentication.SetAuthCookie(UserFlag, createPersistentCookie); createPersistentCookie是否永久保存coo ...

  8. 使用curl制作简易百度搜索

    这几天研究了一下php中的curl类库,做了一个简单的百度搜索,先上代码 <div style="width:200px;height:100px;"> <div ...

  9. Java建造(Builder)模式

    一.什么是建造模式: 建造模式可以将一个产品的内部表象与产品的生成过程分割开来,从而使一个建造过程生成具有不同内部表象的产品.客户端不需要知道产品内部的结构和生产过程. 二.建造模式的结构: Buil ...

  10. vue-cli3 中跨域解决方案

    此方案只能用于开发环境,线上最好设置同源策略(遇到个后端,装你妈批) 前后端不在同一服务器的情况下,前端要访问后端API,可通过在vue.config.js中配置代理服务器. 0:前提条件 1:安装v ...