From 39c82df997c0d637f1d3a33b41b9870f34298a5d Mon Sep 17 00:00:00 2001 From: Sunny Sun <38218185+sunnyosun@users.noreply.github.com> Date: Sat, 19 Oct 2024 00:09:50 +0200 Subject: [PATCH] =?UTF-8?q?=F0=9F=8E=A8=20Fix=20Curator.from=5Fmudata=20(#?= =?UTF-8?q?2082)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lamindb/_curate.py | 25 +++++++++++++++++++++---- 1 file changed, 21 insertions(+), 4 deletions(-) diff --git a/lamindb/_curate.py b/lamindb/_curate.py index 613b9ecb4..b44c361c0 100644 --- a/lamindb/_curate.py +++ b/lamindb/_curate.py @@ -714,7 +714,7 @@ def _save_from_var_index_modality( values=list(self._mdata[modality].var.index), field=self._var_fields[modality], key="var_index", - save_function=".add_new_from_var_index()", + save_function=f'.add_new_from_var_index("{modality}")', using_key=self._using_key, validated_only=validated_only, dtype="number", @@ -840,6 +840,8 @@ def add_new_from( def validate(self, organism: str | None = None) -> bool: """Validate categories.""" + from lamindb.core._settings import settings + self._kwargs.update({"organism": organism} if organism else {}) if self._using_key is not None and self._using_key != "default": logger.important( @@ -847,7 +849,12 @@ def validate(self, organism: str | None = None) -> bool: ) # add all validated records to the current instance - self._update_registry_all() + verbosity = settings.verbosity + try: + settings.verbosity = "error" + self._update_registry_all() + finally: + settings.verbosity = verbosity validated_var = True non_validated_var_modality = {} @@ -859,6 +866,7 @@ def validate(self, organism: str | None = None) -> bool: using_key=self._using_key, source=self._sources.get(modality, {}).get("var_index"), exclude=self._exclude.get(modality, {}).get("var_index"), + validated_hint_print=f'.add_validated_from_var_index("{modality}")', **self._kwargs, # type: ignore ) validated_var &= is_validated_var @@ -1385,19 +1393,28 @@ def _add_labels( if artifact._accessor == "MuData": for modality, modality_fields in fields.items(): + column_field_modality = columns_field.get(modality) if modality == "obs": _add_labels( data, artifact, modality_fields, - feature_ref_is_name=_ref_is_name(columns_field.get("obs")), + feature_ref_is_name=( + None + if column_field_modality is None + else _ref_is_name(column_field_modality) + ), ) else: _add_labels( data[modality], artifact, modality_fields, - feature_ref_is_name=_ref_is_name(columns_field.get(modality)), + feature_ref_is_name=( + None + if column_field_modality is None + else _ref_is_name(column_field_modality) + ), ) else: _add_labels(