- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
底部有两个文件,一个是应该执行的 super 最小 python 文件,一个是 cython 文件。如果将它们保存为文件,将 cython 命名为“cycode.pyx”,一旦执行另一个文件(例如“start.py”),它将自动编译并运行
问题
如果您执行纯 python 文件/.start.py,您将从 Cython 获得一个属性错误。
Exception AttributeError: "'cycode.Item' object has no attribute 'export'" in 'cycode.insertItem'
根据我的经验,这意味着 Python 函数或对象会尝试访问未声明为 public(或 cpdef、readonly、def 等)的 cython 代码。但我从未打算从 Python 访问此函数。据我所知,这不应该发生。 cython 和 python 之间应该有一个清晰的分离。 Python 仅获取包含简单字典的列表。
问题是为什么会这样?我的目标不仅仅是让它工作,这可以通过一个简单的 cpdef 来完成。但要理解为什么会发生这种情况,并最终了解如何以一种干净且受控的方式将数据从 cython 发送到 python,而不必为 python 领域公开任何 cython 对象。
start.py
#! /usr/bin/env python3
# -*- coding: utf-8 -*-
import pyximport; pyximport.install()
import cycode
#Register a callback function with the cython module.
#In this case just attempt to print the data.
cycode.callbacksDatabase.update.append(print)
#Call an insert function to create and insert a cython object.
#We should have nothing to do with this object,
#we just receive a simple list of dict(s) via the callback.
cycode.new1()
cycode.pyx
# cython: language_level=3
cdef class Block:
"""A container class for Items"""
cdef list content
cdef void insert(self, Item item)
cdef list export(self)
def __cinit__(self):
self.content = []
cdef void insert(self, Item item):
self.content.append(item)
cdef list export(self):
"""The frontend should just receive simple data types to
vizualize them. Create export dicts of all items"""
cdef list result
result = []
for item in self.content:
result.append(item.export()) #THIS is the problem. item.export() cannot be found.
return result
cdef class Item:
cdef int value
cdef dict export(self)
def __cinit__(self, int value):
self.value = value
cdef dict export(self):
return {
"id" : id(self),
"value" : self.value,
}
########API#############
class Callbacks():
def __init__(self):
self.update = []
def _update(self):
ex = block.export()
for func in self.update:
func(ex)
cdef void insertItem(int value):
cdef Item item
item = Item(value) #this should create a cython object, not a python one.
block.insert(item)
callbacksDatabase._update()
def new1():
insertItem(1)
#######Actual Data on module level#######
cdef Block block
block = Block() #this is just for the cython code. No direct access from python allowed.
callbacksDatabase = Callbacks() #this should be accesable from python
最佳答案
典型的 IRC 效果...一旦您详细解决了问题,几分钟后就会弹出解决方案(虽然这次是通过 Facebook 聊天...)。
我忘记了在 Python/Cython 中,for 循环不会自动创建一个新的作用域,而且循环变量也没什么特别的。它也需要声明为 cdef。
cdef Item item
for item in self.content:
result.append(item.export())
关于Python 代码找不到 cython 函数,尽管它甚至不应该尝试找到它。为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21149985/
我正在尝试在 Windows 上运行的小于 1GB 的 VM 上设置 YouTrack 和 TeamCity。使用率将非常低(用户和请求)。这是一个 POC 环境,如果它有效,我可能会将它推送到一个超
所以我在尝试使用 FORFILES 解决这个问题时遇到了麻烦。我正在尝试获取不超过 4 天的文件。所以基本上少于 4 天。然而,这似乎不太可能,因为/d -4 获取所有 4 天或更早的项目。 以下是我
如何从下面的 events 表中选择小于 15 分钟前创建的 events? CREATE TABLE events ( created_at timestamp NOT NULL DEFAU
Google Analytics Realtime提供 rt:minutesAgo ,可以过滤查询。 然而,它是一个维度而不是一个度量标准,<=不能在过滤器中使用。 假设我想在最后 n 分钟内获得一些
iOS 核心数据 - 严重的应用程序错误 - 尝试插入 nil 你好, 我的应用程序实际上运行稳定,但在极少数情况下它会崩溃并显示此错误消息... 2019-04-02 20:48:52.437172
我想制作一个 html div 以快速向右移动(例如不到 1 秒)并消失。然后1秒后再次直接出现在这个过程最开始div的位置。此过程将由单击按钮并重复 10 次触发。 我试图在 CSS 中使用过渡属性
我发现使用 TimeTrigger 是 Windows 10 (UWP) 上计划后台任务的方式。但是看起来我们需要给出的最小数字是 15 分钟。只是想知道,即使我们安排它在接下来的 1 分钟内运行,警
我必须在 1 秒内在屏幕上打印 2^20 行整数 printf 不够快,还有其他易于使用的快速输出替代方法吗? 每一行只包含 1 个整数。 我要求它用于竞争性编程问题,我必须将其源代码提交给法官。 最
我是一名优秀的程序员,十分优秀!