- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试编写一个自定义的 SPickler/Unpickler 对来解决当前 scala-pickling 的一些限制。
我试图pickle 的数据类型是一个case 类,其中一些字段已经有自己的SPickler 和Unpickler 实例。
我想在我的自定义pickler 中使用这些实例,但我不知道如何使用。
这是我的意思的一个例子:
// Here's a class for which I want a custom SPickler / Unpickler.
// One of its fields can already be pickled, so I'd like to reuse that logic.
case class MyClass[A: SPickler: Unpickler: FastTypeTag](myString: String, a: A)
// Here's my custom pickler.
class MyClassPickler[A: SPickler: Unpickler: FastTypeTag](
implicit val format: PickleFormat) extends SPickler[MyClass[A]] with Unpickler[MyClass[A]] {
override def pickle(
picklee: MyClass[A],
builder: PBuilder) {
builder.beginEntry(picklee)
// Here we save `myString` in some custom way.
builder.putField(
"mySpecialPickler",
b => b.hintTag(FastTypeTag.ScalaString).beginEntry(
picklee.myString).endEntry())
// Now we need to save `a`, which has an implicit SPickler.
// But how do we use it?
builder.endEntry()
}
override def unpickle(
tag: => FastTypeTag[_],
reader: PReader): MyClass[A] = {
reader.beginEntry()
// First we read the string.
val myString = reader.readField("mySpecialPickler").unpickle[String]
// Now we need to read `a`, which has an implicit Unpickler.
// But how do we use it?
val a: A = ???
reader.endEntry()
MyClass(myString, a)
}
}
最佳答案
这是一个工作示例:
case class MyClass[A](myString: String, a: A)
MyClass
的类型参数不需要上下文边界。只有自定义pickler类需要相应的隐式:
class MyClassPickler[A](implicit val format: PickleFormat, aTypeTag: FastTypeTag[A],
aPickler: SPickler[A], aUnpickler: Unpickler[A])
extends SPickler[MyClass[A]] with Unpickler[MyClass[A]] {
private val stringUnpickler = implicitly[Unpickler[String]]
override def pickle(picklee: MyClass[A], builder: PBuilder) = {
builder.beginEntry(picklee)
builder.putField("myString",
b => b.hintTag(FastTypeTag.ScalaString).beginEntry(picklee.myString).endEntry()
)
builder.putField("a",
b => {
b.hintTag(aTypeTag)
aPickler.pickle(picklee.a, b)
}
)
builder.endEntry()
}
override def unpickle(tag: => FastTypeTag[_], reader: PReader): MyClass[A] = {
reader.hintTag(FastTypeTag.ScalaString)
val tag = reader.beginEntry()
val myStringUnpickled = stringUnpickler.unpickle(tag, reader).asInstanceOf[String]
reader.endEntry()
reader.hintTag(aTypeTag)
val aTag = reader.beginEntry()
val aUnpickled = aUnpickler.unpickle(aTag, reader).asInstanceOf[A]
reader.endEntry()
MyClass(myStringUnpickled, aUnpickled)
}
}
implicit def myClassPickler[A: SPickler: Unpickler: FastTypeTag](implicit pf: PickleFormat) =
new MyClassPickler
关于Scala 酸洗 : Writing a custom pickler/unpickler for nested structures,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19217725/
我有一个对象,它会在第一次使用后被缓存。我将使用 cPickle 模块执行此操作。如果模块已经被缓存,当我下次尝试实例化对象时(在另一个进程中)我想使用缓存的对象。以下是我的基本结构: import
下面的例子 pickles 很好,但是我得到一个编译错误,指出无法生成 unpickler。这是一个简单的测试用例来重现这一点: import scala.pickling._ import json
我有一个文件,其中包含一些我在主脚本中不需要的字典和列表(大约 900 行)。然后我执行以下操作。 myDicts = [DictOne, DictTwo, ListOne, ListTwo] pic
这个问题在这里已经有了答案: Is there a way to view cPickle or Pickle file contents without loading Python in Win
我正在尝试使用 pickle 来保存自定义类;非常类似于下面的代码(尽管在类上定义了一些方法,还有一些用于数据的指令等)。然而,当我运行这个程序时,pickle 然后 unpickle,我丢失了类中的
是否有一种好方法来加载表示为字符串的字节对象,以便可以对其进行 unpickled? 基本示例 这是一个愚蠢的例子: import pickle mydict = { 'a': 1111, 'b':
全局变量 Agree 是在所有函数外部定义的命名元组: Agree = collections.namedtuple('Agree', ['kappa', 'alpha','avg_ao'], ver
我正在使用 python 请求库并尝试保持 session 。 由于我的主机上有多个 IP,我创建了以下方法以使 session 绑定(bind)到特定 IP。 class SourceAddress
我一直在开发一个 python 应用程序,其中客户端向服务器发送时钟信号,而服务器以音频信号响应。 我有两个按钮,一个用于启动时钟,一个用于暂停轨道。 主类 # function I call whe
import pickle class ABError(Exception): def __init__(self, a, b): super(ABError, self)._
我目前正在开发一个 Django 项目,希望通过网络对视频文件进行一些转换。为了对视频进行转换,我使用了 opencv 的 python API,我还使用 Dajax 来执行 ajax 请求。 在 a
当我尝试解开 cifar-10 数据集时,出现以下错误。我需要训练一个模型,但我什至无法获取操作数据。我该如何解决这个问题 dict=cPickle.load(fo) UnpicklingError:
我想实现一个类(最好是单例),在初始化阶段应使用 cPickle 机制恢复其状态。为此,我编写了以下代码片段: import cPickle import collections class Test
我在重命名模块后通过 numpy.load 加载对象时遇到问题。这是一个显示问题的简单示例。 假设在 mymodule.py 中定义了一个类: class MyClass(object): a
As stated in the pickle documentation ,类通常以这样一种方式进行 pickle ,即它们要求完全相同的类出现在接收端的模块中。但是,我确实注意到类还有一些 __g
我有一个我想打开的 pickled 对象,但闲置时返回错误 TypeError: file must have 'read' and 'readline' attributes 这是我的代码 open
我正在编写脚本来通过反复取消对象直到 EOF 来处理(非常大的)文件。我想对文件进行分区并让单独的进程(在云中)解开并处理单独的部分。 但是我的分区器并不智能,它不知道文件中 pickle 对象之间的
目标: 使用带有线程或进程的 SQLAlchemy 在数据库中运行约 40 个巨大的查询,将相应的 SQLA ResultProxies在 Queue.Queue 中(由 multiprocessin
我正在尝试加载 pickle 并通过 Flask 应用程序显示一些数据。我遵循的结构如下。 package1.py class myclass: #do something m = mycla
使用多处理时出现以下错误: Exception in thread Thread-2: Traceback (most recent call last): File "/usr/lib/pyth
我是一名优秀的程序员,十分优秀!