mormot json序列(还原)
mormot json序列(还原)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 | /// <author>cxg 2021-5-28</author> /// delphi7 + mormot1.18 /// json序列\还原 (* people.json [ { "RowID" :3, "FirstName" : "咏南" , "LastName" : "Rachmaninoff" , "Data" : "?w6l6w6di" , "YearOfBirth" :1800, "YearOfDeath" :1943}, { "RowID" :4, "FirstName" : "中间件" , "LastName" : "Dumas" , "Data" : "?w6nDp2I=" , "YearOfBirth" :1801, "YearOfDeath" :1870}, { "RowID" :7, "FirstName" : "rest" , "LastName" : "Huxley" , "Data" : "?w6nDoA==" , "YearOfBirth" :1802, "YearOfDeath" :1963}, ] *) unit Unit1; interface uses mORMot, SynCommons, Contnrs, Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; type TForm1 = class (TForm) Button1: TButton; Memo1: TMemo; Button2: TButton; procedure Button1Click(Sender: TObject); procedure FormCreate(Sender: TObject); procedure Button2Click(Sender: TObject); private { Private declarations } fFileName: string ; public { Public declarations } end; var Form1: TForm1; implementation {$R *.dfm} type TSQLRecordPeople = class (TSQLRecord) private fData: TSQLRawBlob; fFirstName: RawUTF8; fLastName: RawUTF8; fYearOfBirth: integer; fYearOfDeath: word; published property FirstName: RawUTF8 read fFirstName write fFirstName; property LastName: RawUTF8 read fLastName write fLastName; property Data: TSQLRawBlob read fData write fData; property YearOfBirth: integer read fYearOfBirth write fYearOfBirth; property YearOfDeath: word read fYearOfDeath write fYearOfDeath; end; procedure TForm1.Button1Click(Sender: TObject); //从json还原对象1 var json: RawUTF8; i: integer; list: TSQLTableJSON; doc: TObjectList; p: TSQLRecordPeople; begin json := StringFromFile(fFileName); list := TSQLTableJSON.Create( '' ,pointer(json),length(json)); doc := list.ToObjectList(TSQLRecordPeople); list.Free; json := '' ; for i := 0 to doc.Count-1 do begin p := TSQLRecordPeople(doc.List[i]); Memo1.Lines.Add(Utf8ToAnsi(p.fFirstName)); end; doc.Free; end; procedure TForm1.FormCreate(Sender: TObject); begin fFileName := 'people.json' ; Memo1.Clear; end; procedure TForm1.Button2Click(Sender: TObject); //从json还原对象2 var p: TSQLRecordPeople; json: RawUTF8; begin json := StringFromFile(fFileName); p := TSQLRecordPeople.CreateAndFillPrepare(json); json := '' ; while p.FillOne do begin Memo1.Lines.Add(Utf8ToAnsi(p.FirstName)); end; p.Free; end; end. |
本文来自博客园,作者:{咏南中间件},转载请注明原文链接:https://www.cnblogs.com/hnxxcxg/p/14821755.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?