Python导入文本文件并将字符串转换为浮点数

Posted

技术标签:

【中文标题】Python导入文本文件并将字符串转换为浮点数【英文标题】:Python importing a text file and converting string to float 【发布时间】:2021-05-29 15:29:24 【问题描述】:

我在将txt文件输入python时遇到了一些值错误。

名为“htwt.txt”的txt文件,包含以下数据:

Ht Wt

169.6 71.2

166.8 58.2

157.1 56

181.1 64.5

158.4 53

165.6 52.4

166.7 56.8

156.5 49.2

168.1 55.6

165.3 77.8

当我输入以下代码时,出现值错误。

import numpy as np

import pandas as pd

import matplotlib.pyplot as plt

import os


import statsmodels.api as sm

from statsmodels.formula.api import ols


os.chdir("/Users/James/Desktop/data/")

data1=np.loadtxt("htwt.txt") 

df1=pd.DataFrame(data1)

ValueError:无法将字符串转换为浮点数:'Ht'

我可以知道正确的代码应该是什么才能将其转换为数据框吗?谢谢。

【问题讨论】:

【参考方案1】:

熊猫read_csv就够了

import pandas as pd
import os
os.chdir("/Users/James/Desktop/data/")

df1 = pd.read_csv("htwt.txt",sep=' ')

输出:

>>> df1
      Ht    Wt
0  169.6  71.2
1  166.8  58.2
2  157.1  56.0
3  181.1  64.5
4  158.4  53.0
5  165.6  52.4
6  166.7  56.8
7  156.5  49.2
8  168.1  55.6
9  165.3  77.8

检查类型:

>>> df.info()
<class 'pandas.core.frame.DataFrame'>
RangeIndex: 10 entries, 0 to 9
Data columns (total 2 columns):
 #   Column  Non-Null Count  Dtype  
---  ------  --------------  -----  
 0   Ht      10 non-null     float64
 1   Wt      10 non-null     float64
dtypes: float64(2)
memory usage: 288.0 bytes

【讨论】:

【参考方案2】:

如上所述,pandas read_csv 有效,但如果您坚持使用 np.loadtxt,您可以跳过无法转换为浮点数的第一行。你可以这样做:

data1 = np.loadtxt("htwt.txt", skiprows=1)

【讨论】:

请参阅 OP 对 Alexander 回答的评论。【参考方案3】:

文本文件的第一行包含字母数字字符:“Ht Wt”。 这些字符不能转换为浮点数。 删除第一行应该没问题。

【讨论】:

嗨,Alexander,有什么方法不需要删除第一行而是在导入时将它们更改为列名?非常感谢!【参考方案4】:
#for skipping of the first line
file1 = open("hwwt.txt")

lines = file1.readlines()[1:]
for line in lines:
    print(line.rstrip())

OUTPUT
#otherwise you can use read_csv which is enough

【讨论】:

请不要只发布代码作为答案,还要解释您的代码的作用以及它如何解决问题的问题。带有解释的答案通常更有帮助,质量更高,更有可能吸引投票。

以上是关于Python导入文本文件并将字符串转换为浮点数的主要内容,如果未能解决你的问题,请参考以下文章

译将字符转换为双精度浮点型

在python中将字符串转换为数字[关闭]

浮点到 16 位二进制补码二进制,Python

Python:将字符串(科学计数法)转换为浮点数

go 字符串 数字 整型 浮点 转换

如何把excel中的空白转换为数字