我正在从.csv文件中创建一个MLDataTable
,并且想要删除一些行,即特定列具有特定值的所有行-这可能吗?
答案 0 :(得分:4)
我知道我的回答有些迟了,但是希望其他人会觉得有用。
您不能从给定的表中删除行,但是可以创建一个新表,其中某些行被过滤掉。
这是一个示例表:
let employeesDict: [String: MLDataValueConvertible] = [
"First Name": ["Alice", "Bob", "Charlie", "Dave", "Eva"],
"Years of experience": [10, 1, 8, 5, 3],
"Gender": ["female", "male", "male", "male", "female"],
]
let employeesTable = try! MLDataTable(dictionary: employeesDict)
通过将MLDataColumn<Bool>
的实例传递给表的下标运算符来实现过滤。苹果称其为“行掩码”。
这是一个用于屏蔽手工创建的女性实例的行掩码:
let maleEmployeesMaskByHand = MLDataColumn([false, true, true, true, false])
将其作为参数传递给employeesTable
的下标运算符将产生下表:
let maleEmployeesTable = employeesTable[maleEmployeesMaskByHand]
print(maleEmployeesTable)
+----------------+----------------+---------------------+
| Gender | First Name | Years of experience |
+----------------+----------------+---------------------+
| male | Bob | 1 |
| male | Charlie | 8 |
| male | Dave | 5 |
+----------------+----------------+---------------------+
这是构建相同行掩码的另一种方法:
let genderColumn: MLDataColumn<String> = employeesTable["Gender"]
let maleEmployeesMask = genderColumn != "female"
print(employeesTable[maleEmployeesMask])
首先检索所需的列,然后–由于运算符重载–通过将!=
运算符应用于整个列来构建行掩码。
这是一种在同一行中实现相同目标的方法:
print(employeesTable[ employeesTable["Gender"] != "female" ])
相关文档的链接:https://developer.apple.com/documentation/createml/mldatatable/3006094-subscript