提交 767f97cd 编写于 作者: J jiangzhiwen

move GetValue out of try-catch

上级 e4d2f2fd
...@@ -122,16 +122,6 @@ Status ClueOp::Reset() { ...@@ -122,16 +122,6 @@ Status ClueOp::Reset() {
return Status::OK(); return Status::OK();
} }
Status ClueOp::LoadTensor(const std::string &line, std::unique_ptr<TensorQTable> *tensor_table, int64_t row) {
TensorRow tRow(1, nullptr);
(*tensor_table)->push_back(std::move(tRow));
std::shared_ptr<Tensor> tensor;
RETURN_IF_NOT_OK(Tensor::CreateScalar(line, &tensor));
(**tensor_table)[row][0] = std::move(tensor);
return Status::OK();
}
Status ClueOp::GetValue(const nlohmann::json &js, std::vector<std::string> key_chain, std::shared_ptr<Tensor> *t) { Status ClueOp::GetValue(const nlohmann::json &js, std::vector<std::string> key_chain, std::shared_ptr<Tensor> *t) {
nlohmann::json cursor = js; nlohmann::json cursor = js;
for (int i = 0; i < key_chain.size(); i++) { for (int i = 0; i < key_chain.size(); i++) {
...@@ -191,25 +181,24 @@ Status ClueOp::LoadFile(const std::string &file, const int64_t start_offset, con ...@@ -191,25 +181,24 @@ Status ClueOp::LoadFile(const std::string &file, const int64_t start_offset, con
continue; continue;
} }
nlohmann::json js;
try { try {
nlohmann::json js = nlohmann::json::parse(line); js = nlohmann::json::parse(line);
int cols_count = cols_to_keyword_.size();
TensorRow tRow(cols_count, nullptr);
tensor_table->push_back(std::move(tRow));
int cout = 0;
for (auto &p : cols_to_keyword_) {
std::shared_ptr<Tensor> tensor;
RETURN_IF_NOT_OK(GetValue(js, p.second, &tensor));
(*tensor_table)[rows_each_buffer][cout] = std::move(tensor);
cout++;
}
} catch (const std::exception &err) { } catch (const std::exception &err) {
// Catch any exception and convert to Status return code // Catch any exception and convert to Status return code
RETURN_STATUS_UNEXPECTED("Failed to load json file"); RETURN_STATUS_UNEXPECTED("Failed to load json file");
} }
int cols_count = cols_to_keyword_.size();
TensorRow tRow(cols_count, nullptr);
tensor_table->push_back(std::move(tRow));
int cout = 0;
for (auto &p : cols_to_keyword_) {
std::shared_ptr<Tensor> tensor;
RETURN_IF_NOT_OK(GetValue(js, p.second, &tensor));
(*tensor_table)[rows_each_buffer][cout] = std::move(tensor);
cout++;
}
// RETURN_IF_NOT_OK(LoadTensor(line, &tensor_table, rows_each_buffer));
rows_each_buffer++; rows_each_buffer++;
rows_total++; rows_total++;
if (rows_each_buffer == rows_per_buffer_) { if (rows_each_buffer == rows_per_buffer_) {
......
...@@ -179,13 +179,6 @@ class ClueOp : public ParallelOp { ...@@ -179,13 +179,6 @@ class ClueOp : public ParallelOp {
// @return Status - the error code returned. // @return Status - the error code returned.
Status WorkerEntry(int32_t worker_id) override; Status WorkerEntry(int32_t worker_id) override;
// Parses a single row and puts the data into a tensor table.
// @param line - the content of the row.
// @param tensor_table - the tensor table to put the parsed data in.
// @param row - the id of the row filled in the tensor table.
// @return Status - the error code returned.
Status LoadTensor(const std::string &line, std::unique_ptr<TensorQTable> *tensor_table, int64_t row);
// Reads a clue file and loads the data into multiple buffers. // Reads a clue file and loads the data into multiple buffers.
// @param file - the file to read. // @param file - the file to read.
// @param start_offset - the start offset of file. // @param start_offset - the start offset of file.
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册