gpt4 book ai didi

python - 如何在单元测试中使用 pandas 数据框

转载 作者:太空狗 更新时间:2023-10-29 17:12:15 28 4
gpt4 key购买 nike

我正在开发一组 python 脚本来预处理数据集,然后使用 scikit-learn 生成一系列机器学习模型。我想开发一组单元测试来检查数据预处理功能,并希望能够使用一个小型测试 Pandas 数据框,我可以为其确定答案并在断言语句中使用它。

我似乎无法让它加载数据框并使用 self 将其传递给单元测试。我的代码看起来像这样;

def setUp(self):
TEST_INPUT_DIR = 'data/'
test_file_name = 'testdata.csv'
try:
data = pd.read_csv(INPUT_DIR + test_file_name,
sep = ',',
header = 0)
except IOError:
print 'cannot open file'
self.fixture = data

def tearDown(self):
del self.fixture

def test1(self):
self.assertEqual(somefunction(self.fixture), somevalue)

if __name__ == '__main__':
unittest.main()

感谢您的帮助。

最佳答案

Pandas 有一些用于测试的实用程序。

import unittest
import pandas as pd
from pandas.util.testing import assert_frame_equal # <-- for testing dataframes

class DFTests(unittest.TestCase):

""" class for running unittests """

def setUp(self):
""" Your setUp """
TEST_INPUT_DIR = 'data/'
test_file_name = 'testdata.csv'
try:
data = pd.read_csv(INPUT_DIR + test_file_name,
sep = ',',
header = 0)
except IOError:
print 'cannot open file'
self.fixture = data

def test_dataFrame_constructedAsExpected(self):
""" Test that the dataframe read in equals what you expect"""
foo = pd.DataFrame()
assert_frame_equal(self.fixture, foo)

关于python - 如何在单元测试中使用 pandas 数据框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27950891/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com