第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

在拆分它們之前如何避免包含字符串和數(shù)字的行?

在拆分它們之前如何避免包含字符串和數(shù)字的行?

MMTTMM 2021-11-02 20:17:58
我使用python 3,并且我讀取了以幾行包含文本和數(shù)字的行開始的文件,并且從某一行開始它只是數(shù)字列,最初它們?cè)诓鸱趾笠脖蛔x取為str,后來(lái)我將它們轉(zhuǎn)換為浮點(diǎn)數(shù).數(shù)據(jù)看起來(lái)像這樣。我還添加了數(shù)字樣本的鏈接https://gist.github.com/Farzadtb/b0457223a26704093524e55d9b46b1a8所以問(wèn)題是,對(duì)于閱讀,我有兩個(gè)條件(實(shí)際上我希望增加這些條件)使用 try: except 。但這僅適用于劃分拆分方法。但在我開始拆分之前,我需要?jiǎng)h除包含文本的第一行。我知道我應(yīng)該使用除了值錯(cuò)誤但這真的行不通!f = io.open(file, mode="r", encoding="utf-8")    #f=open(file,"r")    lines=f.readlines()    x=[]    y=[]    z=[]        for i in lines:        try:            a=[i.strip('\n')]            a1=[float(n) for n in a[0].split(',')]            atot.append(a1)            x.append(a1[3])            y.append(a1[2])            z.append(a1[1])        except :             a=[i.split('\n')]             a1=[float(n) for n in a[0].split()]             x.append(a1[3])             y.append(a1[2])             z.append(a1[1])問(wèn)題是,由于第一行也可以以數(shù)字開頭,因此第一個(gè)參數(shù)可能會(huì)被拆分并添加到“x”和“y”中,但是我得到了 z 的錯(cuò)誤x=[float(i) for i in x]y=[float(i) for i in y]z=[float(i) for i in z]我想到的一個(gè)想法是檢查該行是否可以無(wú)錯(cuò)誤地轉(zhuǎn)換為浮動(dòng),然后繼續(xù)拆分,但我不知道該怎么做
查看完整描述

1 回答

?
躍然一笑

TA貢獻(xiàn)1826條經(jīng)驗(yàn) 獲得超6個(gè)贊

你應(yīng)該試試這個(gè)。此代碼使用正則表達(dá)式作為一種干凈的方式來(lái)查找數(shù)據(jù)。


import pprint

import re


if __name__ == '__main__':

    # pattern to ignore line containing alpha or :

    ignore_pattern = re.compile(r'[^a-zA-Z:]*[a-zA-Z:]')

    # number pattern

    number_pattern = re.compile(r'[-.\d]+')


    matrix = []


    # open the file as readonly

    with open('data.txt', 'r') as file_:


        # iterator over lines

        for line in file_:

            # remove \n and spaces at start and end

            line = line.strip()

            if not ignore_pattern.match(line):


                found = number_pattern.findall(line)

                if found:

                    floats = [float(x) for x in found]

                    matrix.append(floats)


    # print matrix in pretty format

    pp = pprint.PrettyPrinter()

    pp.pprint(matrix)


    # access value by [row][column] starting at 0

    print(matrix[0][2])

對(duì)您的樣本數(shù)據(jù)進(jìn)行了測(cè)試。這是 python 腳本的標(biāo)準(zhǔn)輸出:


[[-3.1923, 0.6784, -4.6481, -0.0048, 0.3399, -0.2829, 0.0, 24.0477],

 [-3.1827, 0.7048, -4.6257, 0.0017, 0.3435, -0.2855, 0.0, 24.0477],

 [-3.1713, 0.7237, -4.5907, 0.0094, 0.3395, -0.2834, 0.0, 24.0477]]

-4.6481


查看完整回答
反對(duì) 回復(fù) 2021-11-02
  • 1 回答
  • 0 關(guān)注
  • 221 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)