亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

對python .txt文件讀取及數(shù)據(jù)處理方法總結(jié)

 更新時間:2018年04月23日 10:01:55   作者:007lizhen  
下面小編就為大家分享一篇對python .txt文件讀取及數(shù)據(jù)處理方法總結(jié),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

1、處理包含數(shù)據(jù)的文件

最近利用Python讀取txt文件時遇到了一個小問題,就是在計算兩個np.narray()類型的數(shù)組時,出現(xiàn)了以下錯誤:

TypeError: ufunc 'subtract' did not contain a loop with signature matching types dtype('<U3') dtype('<U3') dtype('<U3')

作為一個Python新手,遇到這個問題后花費了挺多時間,在網(wǎng)上找了許多大神們寫的例子,最后終于解決了。

總結(jié)如下:

(1)出現(xiàn)此問題的原因是:目的是想計算兩個數(shù)組間的差值,但數(shù)組中的元素不是數(shù)據(jù)類型(float或int等),而是str類型的。

(2)解決方法:在為空數(shù)組添加數(shù)據(jù)過程中,將每個數(shù)據(jù)強(qiáng)制轉(zhuǎn)化為float型。

如將“character.append(dataSet[i][:-1])”修改為“ character.append([float(tk) for tk in dataSet[i][:-1]])”

現(xiàn)將利用Python讀取txt文件的過程總結(jié)如下:

python版本為python3.6

(1)函數(shù)定義,存放于Function.py文件中:

from numpy import *
import random
#讀取數(shù)據(jù)函數(shù),返回list類型的訓(xùn)練數(shù)據(jù)集和測試數(shù)據(jù)集
def loadData(fileName): 
 trainingData=[]
 testData=[]
 with open(fileName) as txtData:
 lines=txtData.readlines()
 for line in lines:
  lineData=line.strip().split(',') #去除空白和逗號“,”
  if random.random()<0.7:  #數(shù)據(jù)集分割比例
  trainingData.append(lineData) #訓(xùn)練數(shù)據(jù)集
  else:
  testData.append(lineData) #測試數(shù)據(jù)集
 return trainingData,testData
#輸入數(shù)據(jù)為list類型,分割數(shù)據(jù)集,分割為特征和標(biāo)簽兩部分,返回數(shù)據(jù)為np.narray類型
def splitData(dataSet): 
 character=[]
 label=[]
 for i in range(len(dataSet)):
 character.append([float(tk) for tk in dataSet[i][:-1]])
 label.append(dataSet[i][-1])
 return array(character),array(label)

(2)實現(xiàn)兩個數(shù)組間的減法,存放于main.py文件中:

#__author__=='qustl_000'
#-*- coding: utf-8 -*-
import numpy as np
import Function
fileName="1.txt"
trainingData,testData=Function.loadData(fileName)
trainingCharacter,trainingLabel=Function.splitData(trainingData)
testCharacter,testLabel=Function.splitData(testData)
diff1=np.tile(testCharacter[0],(len(trainingCharacter),1))-trainingCharacter
print('測試數(shù)據(jù)集的一條數(shù)據(jù),擴(kuò)充到與訓(xùn)練數(shù)據(jù)集同維:')
print(np.tile(testCharacter[0],(len(trainingCharacter),1)))
print('訓(xùn)練數(shù)據(jù)集:')
print(trainingCharacter)
print('作差后的結(jié)果:')
print(diff1)

(3)運行結(jié)果:

測試數(shù)據(jù)集的一條數(shù)據(jù),擴(kuò)充到與訓(xùn)練數(shù)據(jù)集同維:
[[ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]
 [ 1.5 60. ]]
訓(xùn)練數(shù)據(jù)集:
[[ 1.5 40. ]
 [ 1.5 50. ]
 [ 1.6 40. ]
 [ 1.6 50. ]
 [ 1.6 60. ]
 [ 1.6 70. ]
 [ 1.7 60. ]
 [ 1.7 70. ]
 [ 1.7 80. ]
 [ 1.8 60. ]
 [ 1.8 80. ]
 [ 1.8 90. ]
 [ 1.9 90. ]]
作差后的結(jié)果:
[[ 0. 20. ]
 [ 0. 10. ]
 [ -0.1 20. ]
 [ -0.1 10. ]
 [ -0.1 0. ]
 [ -0.1 -10. ]
 [ -0.2 0. ]
 [ -0.2 -10. ]
 [ -0.2 -20. ]
 [ -0.3 0. ]
 [ -0.3 -20. ]
 [ -0.3 -30. ]
 [ -0.4 -30. ]]

數(shù)據(jù)集如下:

1.5,40,thin
1.5,50,fat
1.5,60,fat
1.6,40,thin
1.6,50,thin
1.6,60,fat
1.6,70,fat
1.7,50,thin
1.7,60,thin
1.7,70,fat
1.7,80,fat
1.8,60,thin
1.8,70,thin
1.8,80,fat
1.8,90,fat
1.9,80,thin
1.9,90,fat

2、處理文本文件,如情感識別類的文件

在進(jìn)行文本的情感分類時,從電影評論數(shù)據(jù)集網(wǎng)站上下載數(shù)據(jù)集后,發(fā)現(xiàn)數(shù)據(jù)集中存在許多不需要的符號。截取部分包含多余字符的數(shù)據(jù)如下:

下載數(shù)據(jù)集后,所有txt文件存放在兩個文件夾:“neg”(包含消極評論)和“pos”(包含積極地評論)中。

兩者的存放目錄如下:“F:\Self_Learning\機(jī)器學(xué)習(xí)\python\Bayes\review_polarity\txt_sentoken”。后面需要用到文件路徑,此路徑可根據(jù)自己存放目錄修改。

主要涉及到的python操作有:多余字符的刪除、文件夾中多文件的操作。

2.1 多余字符的刪除

首先,我們要刪除多余的符號,獲得干凈的數(shù)據(jù)。

經(jīng)過查找資料,知道刪除一條文本數(shù)據(jù)中不需要的符號,可以通過re.sub(chara,newChara,data)函數(shù)實現(xiàn),其中chara是需要刪除的字符,newChara是刪除字符后相應(yīng)位置的替換字符,data是需要操作的數(shù)據(jù)。比如下面的代碼,指的是刪除lines中包含的前面列出的字符,并用空白替換:

lineString = re.sub("[\n\.\!\/_\-$%^*(+\"\')]+|[+—()?【】“”!:,;.?、~@#¥%…&*()0123456789]+", " ", lines)

2.2 python對多文件的操作

下面的程序中,pathDirPos指的是所有積極評論的txt文件所在的目錄,在此指的是“F:\Self_Learning\機(jī)器學(xué)習(xí)\python\Bayes\review_polarity\txt_sentoken\pos”。child就是獲得的每個txt文件全名。

 for allDir in pathDirPos:
 child = os.path.join('%s' % allDir)

2.3 電影評論數(shù)據(jù)集預(yù)處理

下面給出對于電影評論數(shù)據(jù)集的預(yù)處理程序(python3.6).

'''獲取數(shù)據(jù),并去除數(shù)據(jù)中的多余符號,返回list類型的數(shù)據(jù)集'''
def loadData(pathDirPos,pathDirNeg):
 posAllData = [] # 積極評論
 negAllData = [] # 消極評論
 # 積極評論
 for allDir in pathDirPos:
 lineDataPos = []
 child = os.path.join('%s' % allDir)
 filename = r"review_polarity/txt_sentoken/pos/" + child
 with open(filename) as childFile:
  for lines in childFile:
  lineString = re.sub("[\n\.\!\/_\-$%^*(+\"\')]+|[+—()?【】“”!:,;.?、~@#¥%…&*()0123456789]+", " ", lines)
  line = lineString.split(' ') #用空白分割每個文件中的數(shù)據(jù)集(此時還包含許多空白字符)
  for strc in line:
   if strc != "" and len(strc) > 1: #刪除空白字符,并篩選出長度大于1的單詞
   lineDataPos.append(strc)
  posAllData.append(lineDataPos)
 # 消極評論
 for allDir in pathDirNeg:
 lineDataNeg = []
 child = os.path.join('%s' % allDir)
 filename = r"review_polarity/txt_sentoken/neg/" + child
 with open(filename) as childFile:
  for lines in childFile:
  lineString = re.sub("[\n\.\!\/_\-$%^*(+\"\')]+|[+—()?【】“”!:,;.?、~@#¥%…&*()0123456789]+", " ", lines)
  line = lineString.split(' ') #用空白分割每個文件中的數(shù)據(jù)集(此時還包含許多空白字符)
  for strc in line:
   if strc != "" and len(strc) > 1: #刪除空白字符,并篩選出長度大于1的單詞
   lineDataNeg.append(strc)
  negAllData.append(lineDataNeg)
 return posAllData,negAllData
'''劃分?jǐn)?shù)據(jù)集,將數(shù)據(jù)集劃分為訓(xùn)練數(shù)據(jù)和測試數(shù)據(jù),參數(shù)splitPara為分割比例'''
def splitDataSet(pathDirPos,pathDirNeg,splitPara):
 trainingData=[]
 testData=[]
 traingLabel=[]
 testLabel=[]
 posData,negData=loadData(pathDirPos,pathDirNeg)
 pos_len=len(posData)
 neg_len=len(negData)
 #操作積極評論數(shù)據(jù)
 for i in range(pos_len):
 if(random.random()<splitPara):
  trainingData.append(posData[i])
  traingLabel.append(1)
 else:
  testData.append(posData[i])
  testLabel.append(1)
 for j in range(neg_len):
 if(random.random()<splitPara):
  trainingData.append(negData[j])
  traingLabel.append(0)
 else:
  testData.append(negData[j])
  testLabel.append(0)
 return trainingData,traingLabel,testData,testLabel

以上這篇對python .txt文件讀取及數(shù)據(jù)處理方法總結(jié)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • django haystack實現(xiàn)全文檢索的示例代碼

    django haystack實現(xiàn)全文檢索的示例代碼

    這篇文章主要介紹了django haystack實現(xiàn)全文檢索的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • OpenCV中Canny邊緣檢測的實現(xiàn)

    OpenCV中Canny邊緣檢測的實現(xiàn)

    本文主要介紹了OpenCV中Canny邊緣檢測的實現(xiàn),邊緣檢測一般是識別目標(biāo)圖像中亮度變化明顯的像素點,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • python中playwright結(jié)合pytest執(zhí)行用例的實現(xiàn)

    python中playwright結(jié)合pytest執(zhí)行用例的實現(xiàn)

    本文主要介紹了python中playwright結(jié)合pytest執(zhí)行用例的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • python如何設(shè)置靜態(tài)變量

    python如何設(shè)置靜態(tài)變量

    在本篇內(nèi)容里小編給大家整理的是一篇關(guān)于python如何設(shè)置靜態(tài)變量的相關(guān)文章,有興趣的朋友們可以參考下。
    2020-09-09
  • python 去除二維數(shù)組/二維列表中的重復(fù)行方法

    python 去除二維數(shù)組/二維列表中的重復(fù)行方法

    今天小編就為大家分享一篇python 去除二維數(shù)組/二維列表中的重復(fù)行方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • Python寫腳本常用模塊OS基礎(chǔ)用法詳解

    Python寫腳本常用模塊OS基礎(chǔ)用法詳解

    這篇文章主要介紹了Python寫腳本常用模塊OS基礎(chǔ)用法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Python生成器與迭代器詳情

    Python生成器與迭代器詳情

    這篇文章主要介紹了Python生成器與迭代器,現(xiàn)在可以通過生成器來直接創(chuàng)建一個列表,是由于內(nèi)存的限制,表的容量肯定是有限的,果我們需要一個包含幾百個元素的列表,是每次訪問的時候只訪問其中的幾個,剩下的元素不使用就很浪費內(nèi)存空間,下面來了解具體內(nèi)容
    2021-11-11
  • Python就將所有的英文單詞首字母變成大寫

    Python就將所有的英文單詞首字母變成大寫

    這篇文章主要給大家介紹了關(guān)于Python就將所有的英文單詞首字母變成大寫的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Python socket實現(xiàn)簡單聊天室

    Python socket實現(xiàn)簡單聊天室

    這篇文章主要為大家詳細(xì)介紹了Python socket實現(xiàn)簡單聊天室,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • 在Mac中PyCharm配置python Anaconda環(huán)境過程圖解

    在Mac中PyCharm配置python Anaconda環(huán)境過程圖解

    這篇文章主要介紹了在Mac中PyCharm配置python Anaconda環(huán)境過程圖解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03

最新評論