Translate

ebook【Delphi跨平台資料庫程式設計火速上手】電子書出版 (CHT)

Delphi 跨平台資料庫程式設計火速上手,是本關於整合 Delphi 的跨平台技術打造 2-Tier 架構的跨平台 APP 的入門技術書。 全書沒有需要理解的技術知識,只講套路。 力求短時間把製作 APP 的工法熟悉,未來要開發其它的應用程式也能舉一反三。 底下...

2017/06/26

JSON Parse in Delphi XE (01)

在 Delphi.ktop 的主題中,看到了【JSON求教】這一篇

如果在 XE 裡面要實現,是不是也是這麼簡單?

想到了,就開始來實作吧!


首先是 Download 的部份:
procedure TForm1.Button1Click(Sender: TObject);
var
  ss: string;
  ssm: TStringStream;
begin
  Memo1.Clear;
  ssm := TStringStream.Create('', TEncoding.UTF8);
  ss := IdHTTP1.Get('https://blockchain.info/ticker');
  IdHTTP1.Get('https://blockchain.info/ticker', ssm);
  Memo1.Lines.Add(ssm.DataString);
  ssm.Free;
end;

接著是 JSON Parse 的部份:
procedure TForm1.Button2Click(Sender: TObject);
var
  LJSObj, LJSSubObj: TJSONObject;
  LJSPair: TJSONPair;
  LJSVal: TJSONValue;
  LPos01: Integer;
  LStr: string;
begin
  LJSObj := TJSONObject.ParseJSONValueUTF8(TEncoding.UTF8.GetBytes(Memo1.Text), 0) as TJSONObject;
  Memo1.Clear;
  if LJSObj <> nil then
  begin
    for LPos01 := 0 to LJSObj.Size-1 do
    begin
      try
        LJSPair := LJSObj.Get(LPos01);
        LJSSubObj := LJSPair.JsonValue as TJSONObject;
        LStr := LJSSubObj.Get('15m').JsonValue.Value;
        Memo1.Lines.Add(LJSSubObj.Get('15m').JsonValue.Value);
        Memo1.Lines.Add(LJSSubObj.Get('last').JsonValue.Value);
        Memo1.Lines.Add(LJSSubObj.Get('buy').JsonValue.Value);
        Memo1.Lines.Add(LJSSubObj.Get('sell').JsonValue.Value);
        Memo1.Lines.Add(LJSSubObj.Get('symbol').JsonValue.Value);
      except
        on E: Exception do
        begin
          Memo1.Lines.Add('Error: '+LJSSubObj.ToString);
          Exit;
        end;
      end;
    end;
  end;
end;

和前版的 Delphi 有很大的落差,畢竟新版擴充的更加完美,但現階段仍然可以解決解析的問題。


於是我們就得到了以下的內容:
解析後的結果

 得到了一個例外,看來是 UNICODE 的問題,到底該怎麼解呢?

欲知詳情,我們下回待續!

沒有留言:

張貼留言