因此,出于测试目的,我尝试从json文件创建python ActiveResource对象(我希望该对象具有json文件中的属性)。更具体地说,我正在使用(https://github.com/Shopify/shopify_python_api)中的ShopifyResource,它扩展了ActiveResource对象。

我浏览了源代码,发现一些我认为有用的功能:
https://github.com/Shopify/shopify_python_api/blob/master/shopify/base.py

from pyactiveresource.activeresource import ActiveResource
import shopify.mixins as mixins

class ShopifyResource(ActiveResource, mixins.Countable):
    _format = formats.JSONFormat

    def _load_attributes_from_response(self, response):
        if response.body.strip():
            self._update(self.__class__.format.decode(response.body))


_update来自ActiveResource(https://github.com/Shopify/pyactiveresource/blob/master/pyactiveresource/activeresource.py

    def _update(self, attributes):
        """Update the object with the given attributes.

        Args:
            attributes: A dictionary of attributes.
        Returns:
            None
        """
        if not isinstance(attributes, dict):
            return
        for key, value in six.iteritems(attributes):
            if isinstance(value, dict):
                klass = self._find_class_for(key)
                attr = klass(value)
            elif isinstance(value, list):
                klass = None
                attr = []
                for child in value:
                    if isinstance(child, dict):
                        if klass is None:
                            klass = self._find_class_for_collection(key)
                        attr.append(klass(child))
                    else:
                        attr.append(child)
            else:
                attr = value
            # Store the actual value in the attributes dictionary
            self.attributes[key] = attr


因此,我尝试执行以下操作:

order = Order()
with open("file.json")) as json_file:
    x = json.loads(json_file.read())
    order._update(x)


顺序扩展ShopifyResource(扩展ActiveResource)的位置。如果没记错的话,x应该是字典,它是_update()函数的适当参数。

但是我得到以下输出:

raceback (most recent call last):
  File "/home/vineet/Documents/project/tests/test_sync.py", line 137, in testSaveOrder1
    self.getOrder()
  File "/home/vineet/Documents/project/tests/tests/test_sync.py", line 113, in getOrder
    order._update(x)
  File "/home/vineet/Documents/project/venv/lib/python3.6/site-packages/pyactiveresource/activeresource.py", line 962, in _update
    attr.append(klass(child))
  File "/home/vineet/Documents/project/venv/lib/python3.6/site-packages/shopify/base.py", line 126, in __init__
    prefix_options, attributes = self.__class__._split_options(attributes)
  File "/home/vineet/Documents/project/venv/lib/python3.6/site-packages/pyactiveresource/activeresource.py", line 466, in _split_options
    if key in cls._prefix_parameters():
  File "/home/vineet/Documents/project/venv/lib/python3.6/site-packages/pyactiveresource/activeresource.py", line 720, in _prefix_parameters
    for match in template.pattern.finditer(path):
TypeError: cannot use a string pattern on a bytes-like object



我什至尝试了以下方法:

 order._update(order._format.decode(json_file.read()))


但这没有用,因为'str'对象没有属性'decode'。

最佳答案

您似乎担心x是否具有正确的格式。打印并检查。

顺便说一句:并使用

x = json.load(json_file)


代替

x = json.loads(json_file.read())

关于python - 从json文件创建Python Active Resource对象,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/56468796/

10-12 01:55