python获取txt文件词向量过程详解


Posted in Python onJuly 05, 2019

在读取https://github.com/Embedding/Chinese-Word-Vectors中的中文词向量时,选择了一个有3G多的txt文件,之前在做词向量时用的是word2vec,所以直接导入模型然后indexword即可。

因为这是一个txt大文件,尝试了DataFrame,np.loadtxt等,都没有成功,其中主要遇到的问题是:

  • 如何读取完整的大文件,而不会出现内存不足memery error等问题
  • 将读取出来的文件,保存为npy文件
  • 根据词找到对应的向量

解决办法

尝试使用的代码:

代码1:
try:
lines=np.loadtxt(filepath)
catch:
感觉这块不会写了咦,,,
  print(ValueError)
但这样的话,它就不会继续循环去读上边的txt了呢
代码2:
lines=[]
with open(filepath) as f:
  for line in f:
    lines.append(line)
np.save(filepath,lines)
代码3
 
def readEmbedFile(embedFile):
#   embedId = {}
#   input = open(embedFile,'r',encoding="utf-8")
#   lines = []
#   a=0
#   for line in input:
#     lines.append(line)
#     a=a+1
#     print(a)
#   nwords = len(lines) - 1
#   splits = lines[1].strip().split(' ') # 因为第一行是统计信息,所以用第二行
#   dim = len(splits) - 1
#   embeddings=[]
#   # embeddings = [[0 for col in range(dim)] for row in range(nwords)]
#   b=0
#   for lineId in range(len(lines)):
#     b=b+1
#     print(b)
#     splits = lines[lineId].split(' ')
#     if len(splits) > 2:
#       # embedId赋值
#       embedId[splits[0]] = lineId
#       # embeddings赋值
#       emb = [float(splits[i]) for i in range(1, 300)]
#       embeddings.append(emb)
#   return embedId, embeddings
代码4:
def load_txt(filename):
  lines=[]
  vec_dict={}
  with open(filename,r) as f:
    for line in f:
    list=line.strip()
    lines.append(line)
  for i, line in emuate(lines):
    if i=0:
      continue
    line=line.split(" ")
    wordID=line[0]
    wordvec=[float line[i] for i in range(1,300)]
  vec_dict[wordId]=np.array(wordvec)  
 
  return vec_dict

具体内存不足主要的原因是:

我的虚拟机中确实内存不太够,后来使用实验室32G的主机后,可以得到idvec,而得不到向量的,报的错还是memory error.
另一个原因,是需要把词向量转换为float形式,在python中str 占的内存>float类型,如代码所示:

print("str",sys.getsizeof(""))
print("float",sys.getsizeof(1.1))
print("int",sys.getsizeof(1))
print("list",sys.getsizeof([]))
print("tuple",sys.getsizeof(()))
print("dic",sys.getsizeof([]))
str 49
float 24
int 28
list 64
tuple 48
dic 64

在我的电脑,64位操作系统,64位的python, 所占内存大小排序为:

dic=list>str>tuple>int>float

读取时候可以用np.load().item就可以复原原来的字典,主要参照下述文件:

然后通过python的字典操作就可以遍历得到每个词的词向量了,dic[vocab]

心得

距离完全解决项目的问题还有5~6的大关卡,但静下心来,一步步地做总会突破的呀!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python验证码识别的实例详解
Sep 09 Python
python将一个英文语句以单词为单位逆序排放的方法
Dec 20 Python
Python常见数据结构之栈与队列用法示例
Jan 14 Python
Appium+python自动化之连接模拟器并启动淘宝APP(超详解)
Jun 17 Python
python 微信好友特征数据分析及可视化
Jan 07 Python
Python终端输出彩色字符方法详解
Feb 11 Python
django xadmin action兼容自定义model权限教程
Mar 30 Python
解决json中ensure_ascii=False的问题
Apr 03 Python
django orm模块中的 is_delete用法
May 20 Python
python中对二维列表中一维列表的调用方法
Jun 07 Python
python对 MySQL 数据库进行增删改查的脚本
Oct 22 Python
Pytorch中的学习率衰减及其用法详解
Jun 05 Python
Python 的字典(Dict)是如何存储的
Jul 05 #Python
关于Python 的简单栅格图像边界提取方法
Jul 05 #Python
Python3+Appium安装使用教程
Jul 05 #Python
Python叠加两幅栅格图像的实现方法
Jul 05 #Python
用vue.js组件模拟v-model指令实例方法
Jul 05 #Python
python买卖股票的最佳时机(基于贪心/蛮力算法)
Jul 05 #Python
Python 计算任意两向量之间的夹角方法
Jul 05 #Python
You might like
PHP+javascript模拟Matrix画面
2006/10/09 PHP
php时间戳格式化显示友好的时间函数分享
2014/10/21 PHP
PHP实现根据银行卡号判断银行
2015/04/29 PHP
PHP GD库相关图像生成和处理函数小结
2016/09/30 PHP
PHP替换Word中变量并导出PDF图片的实现方法
2020/11/26 PHP
jQuery中append、insertBefore、after与insertAfter的简单用法与注意事项
2020/04/04 Javascript
JS打开层/关闭层/移动层动画效果的实例代码
2013/05/11 Javascript
JS获取屏幕,浏览器窗口大小,网页高度宽度(实现代码)
2013/12/17 Javascript
jQuery中:image选择器用法实例
2015/01/03 Javascript
JavaScript对象学习小结
2015/09/02 Javascript
jquery zTree异步加载、模糊搜索简单实例分享
2016/03/24 Javascript
原生态js,鼠标按下后,经过了那些单元格的简单实例
2016/08/11 Javascript
微信小程序 location API接口详解及实例代码
2016/10/12 Javascript
浅谈es6 javascript的map数据结构
2017/12/14 Javascript
微信小程序实现预览图片功能
2020/10/22 Javascript
React 实现拖拽功能的示例代码
2019/01/06 Javascript
实现elementUI表单的全局验证的方法步骤
2019/04/29 Javascript
Bootstrap FileInput实现图片上传功能
2021/01/28 Javascript
[01:20:47]DOTA2-DPC中国联赛 正赛 Ehome vs Magma BO3 第一场 1月19日
2021/03/11 DOTA
实例详解Python装饰器与闭包
2019/07/29 Python
django-csrf使用和禁用方式
2020/03/13 Python
opencv 图像轮廓的实现示例
2020/07/08 Python
python如何遍历指定路径下所有文件(按按照时间区间检索)
2020/09/14 Python
美国女性服饰销售网站:Nasty Gal(坏女孩)
2016/07/26 全球购物
大专生简历的自我评价
2013/11/26 职场文书
领导视察欢迎词
2014/01/15 职场文书
护士演讲稿优秀范文
2014/04/30 职场文书
美食节目策划方案
2014/05/31 职场文书
工厂标语大全
2014/10/06 职场文书
报到证办理个人委托书
2014/10/06 职场文书
学生考试舞弊检讨书
2015/01/01 职场文书
建筑技术负责人岗位职责
2015/04/13 职场文书
关于调整工作时间的通知
2015/04/24 职场文书
python 用递归实现通用爬虫解析器
2021/04/16 Python
MYSQL主从数据库同步备份配置的方法
2021/05/26 MySQL
你真的会用Mysql的explain吗
2022/03/31 MySQL