2013-08-22 11 views
18

sto usando protocollo buffer pitone lib per inviare i dati, ma è avere alcuni problemi, in modo daAttributeError: Assegnazione non ha permesso di campo composito "compito" in oggetto messaggio di protocollo

Traceback (most recent call last): 
    File "test_message.py", line 17, in <module> 
    ptask.task = task 
    File "build\bdist.win32\egg\google\protobuf\internal\python_message.py", line 
513, in setter 
AttributeError: Assignment not allowed to composite field "_task" in protocol message object. 

lo src come segue:

file di proto: codice

message task { 
    required int32 id = 1; 
    required string msg = 2; 
} 

message task_info { 
    required task task = 1; 
} 

pitone:

task = yacc.task() 
task.id = 1000 
task.msg = u"test" 
ptask = yacc.task_info() 
ptask.task = task # this line happen the runtime error 

risposta

15

Non so protocollo-buffer ma ho preso uno sguardo al the docs e dice:

You cannot assign a value to an embedded message field. Instead, assigning a value to any field within the child message implies setting the message field in the parent.

Così sto assumendo questo dovrebbe funzionare:

task = yacc.task() 
task.id = 1000 
task.msg = u"test" 
ptask = yacc.task_info() 
ptask.task.id = task.id 
ptask.task.msg = task.msg 
14

Sono nuovo anche per i buffer di protocollo e con lo stesso problema. Ho trovato utile this method.

penso che dovrebbe funzionare:

task = yacc.task() 
task.id = 1000 
task.msg = u"test" 
ptask = yacc.task_info() 
ptask.task.MergeFrom(task) 
29

Prova CopyFrom:

ptask.task.CopyFrom(task) 
Problemi correlati