へっぽこプログラマーの備忘録
プログラムを中心とした個人的なメモ用のブログです。 タイトルは迷走中。
内容の保証はできませんのであしからずご了承ください。
menu
keyboard_arrow_up
Top
search
close
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
Home
›
C#
›
[C#] Cryptowatch API で取得した JSON をデシリアライズする
2018/10/04
[C#] Cryptowatch API で取得した JSON をデシリアライズする
update
event_note
label
C#
予想外にはまったのでメモしておきます。 パーサーは Newtonsoft.Json(JSON.NET) を使用します。
Cryptowatch API で取得したデータは以下のような JSON 形式となっています。 ```json { "result": { "60": [ [1481634360, 782.14, 782.14, 781.13, 781.13, 1.92525], [1481634420, 782.02, 782.06, 781.94, 781.98, 2.37578], [1481634480, 781.39, 781.94, 781.15, 781.94, 1.68882], ... ], "180": [...], "300": [...], ... "604800": [...] } } ``` インタプリタ言語とかだと何も考えずにデシリアライズ可能なのですが、これを C# でデシリアライズしようとすると結構面倒です。 (もっと簡単な方法があれば教えていただきたいです) まず、`result` 以下のキー(`60`とか`180`とか)がクエリに応じて動的に変わるので、`Dictionary` を使用します。 また、値の部分が配列の入れ子になっているので、`Dictionary` の `Value` は `List` の入れ子にします。 さらに最下層の Value が整数だったり浮動小数だったり、時刻は Unix タイムなので DateTime 型に変換したいとかあるので、`List` の型は `String` にしておき、後で個別にパースしていきます。 まずデシリアライズ用の型として以下のような構造体を定義します。 ```cs public struct CryptowatchResponse { public Dictionary
>> Result { get; set; } } ``` 以下のようにして Cryptowatch からデータを取得してデシリアライズします。 ```cs var before = DateTimeOffset.Now.ToUnixTimeSeconds(); CryptowatchResponse json; using (var client = new HttpClient()) using (var response = client.GetAsync($"https://api.cryptowat.ch/markets/bitflyer/btcfxjpy/ohlc?before={before}").Result) { var contents = response.Content.ReadAsStringAsync().Result; json = JsonConvert.DeserializeObject
(contents); } ``` 尚、ここでは `HttpClient` を `Using` していますが、普通はコンストラクタ等でインスタンス化して使いまわすようです。 (詳細はググってください) さらに、ここから `string` 型で持っている値を適切な型に変換します。 (文字列のままで良ければこれは不要です) まず各要素の値を入れるための構造体を以下のように定義します。 ```cs public struct CryptowatchData { public DateTime Time { get; set; } public double Open { get; set; } public double High { get; set; } public double Low { get; set; } public double Close { get; set; } public double Volume { get; set; } } ``` あとは愚直に変換してくだけです。 例えば、一分足のデータを変換したい場合は以下のような感じです。 ```cs var records = new List
(); foreach (var record in json.Result[60]) { records.Add(new CryptowatchData() { // unixtime から JST に変換する Time = DateTimeOffset.FromUnixTimeSeconds(long.Parse(record[0])).LocalDateTime, Open = double.Parse(record[1]), High = double.Parse(record[2]), Low = double.Parse(record[3]), Close = double.Parse(record[4]), Volume = double.Parse(record[5]), }); } ``` もっと簡単に書けないかなぁとは思いますけど、とりあえずこんな感じです。
## 参考 URL - https://blog.okazuki.jp/entry/2014/04/19/235806
tweet
facebook
Pocket
B!
はてブ
LINE
chevron_left
chevron_right
Translate
Popular Posts
TortoiseGit でコミットメッセージを変更する
image
NO IMAGE
smbclient で session setup failed: NT_STATUS_LOGON_FAILURE が表示される
Docker for Windows の設定
image
NO IMAGE
TortoiseSVN ロック状態のチェック
image
NO IMAGE
マージ元ブランチとマージ先ブランチ
image
NO IMAGE
Visual Studio で文字がにじむ(ぼやける)
TortoiseGit でブランチ間の差分を見る
image
NO IMAGE
AsciidocFX をビルドする
image
NO IMAGE
PowerShellでブレークポイントが設定できない場合
[Python] 文字列の判定で、None と空文字を同時に判定する
Labels
.NET Core
31
.NET Framework
17
.NET Standard
2
AdminLTE
1
AI
1
Apache
3
AppVeyor
2
AsciiDoc
7
ASP.NET Core
55
Atom
4
AWS
5
AWS Cloud9
4
blockdiag
1
Blogger
13
Bootstrap
3
C/C++
6
C#
106
CentOS
3
Chrome
1
Chronograf
3
chrony
1
Codecov
1
CSS
1
Docker
82
DokuWiki
4
Doxygen
1
draw.io
1
EasyTag
1
Electron
1
Electron.NET
2
Entity Framework Core
9
Excel
2
FFmpeg
3
Firefox
6
Flask
1
Git
19
GitBook
4
GitBucket
7
GitHub
7
GitLab
39
Go
1
Google
1
Google Cloud Platform
1
Grafana
13
GStreamer
2
HTML
5
IIS
8
InfluxDB
14
JavaScript
15
Jekyll
3
Jenkins
7
Linux
34
Log4View
1
MahApps.Metro
3
MaterialDesignInXamlToolkit
1
MkDocs
2
MongoDB
5
MVC
1
MVVM
6
nginx
3
NLog
3
Node.js
8
npm
1
NVIDIA
3
onvif
1
OpenAPI
2
OpenCV
4
OpenSSL
3
OpenVINO
2
ownCloud
2
pandas
1
Pine Script
1
PlantUML
5
Portainer
3
PowerShell
8
Prism
2
PySide
19
Python
88
PyTorch
1
RabbitVCS
1
Razor
3
redis
1
Redmine
33
Redoc
1
remark.js
2
rocketchat
10
Ruby
3
scikit-learn
1
shotcut
1
SignalR
1
Slack
1
Socket.IO
1
SonarQube
5
Sphinx
10
SQL Server
5
SQLite
1
StableDiffusion
2
Subversion
2
Swagger
1
Swarmpit
1
Syslog
3
Telegraf
6
Tesseract
3
TestLink
2
Tomcat
2
TortoiseGit
11
TortoiseSVN
2
Trading View
1
Traefik
3
Travis CI
1
Ubuntu
31
Visual Studio
39
Visual Studio Code
10
VSCode
8
Vue.js
8
Windows
62
Windows 10
5
Windows ADK
1
Windows API
2
Windows Embedded
4
wkhtmltopdf
2
Word
3
WPF
12
WSL
5
WSL2
5
Xamarin
1
xUnit
5
yaml
1
yolo
1
アプリケーション
1
デザインパターン
1
テスト
1
バッチファイル
2
プログラミング
4
ライセンス
1
暗号資産(仮想通貨)
1
英語
2
確定申告
1
機械学習
1
強化学習
1
雑記
1
書籍
1
数学
1
正規表現
1
動画編集
1
Blog Archive
►
2024
(21)
►
12月
(3)
►
9月
(5)
►
8月
(1)
►
7月
(2)
►
6月
(1)
►
4月
(2)
►
3月
(1)
►
2月
(5)
►
1月
(1)
►
2023
(30)
►
12月
(3)
►
11月
(5)
►
10月
(2)
►
9月
(1)
►
8月
(2)
►
7月
(4)
►
6月
(2)
►
5月
(3)
►
4月
(2)
►
3月
(2)
►
2月
(3)
►
1月
(1)
►
2022
(106)
►
12月
(5)
►
11月
(1)
►
10月
(3)
►
9月
(6)
►
8月
(7)
►
7月
(6)
►
6月
(13)
►
5月
(9)
►
4月
(15)
►
3月
(11)
►
2月
(14)
►
1月
(16)
►
2021
(85)
►
12月
(11)
►
11月
(6)
►
10月
(4)
►
9月
(10)
►
8月
(8)
►
7月
(4)
►
6月
(18)
►
5月
(7)
►
4月
(8)
►
3月
(2)
►
2月
(2)
►
1月
(5)
►
2020
(56)
►
12月
(1)
►
11月
(3)
►
10月
(3)
►
9月
(3)
►
8月
(3)
►
7月
(7)
►
6月
(7)
►
5月
(2)
►
4月
(6)
►
3月
(6)
►
2月
(3)
►
1月
(12)
►
2019
(92)
►
12月
(13)
►
11月
(9)
►
10月
(3)
►
9月
(2)
►
8月
(3)
►
7月
(5)
►
6月
(11)
►
5月
(6)
►
4月
(17)
►
3月
(9)
►
2月
(6)
►
1月
(8)
▼
2018
(100)
►
12月
(1)
►
11月
(11)
▼
10月
(8)
NLog の 例外情報内のスタックトレースの改行を無効化する
Word のフィールドの自動更新に関するオプションの挙動
[C#] 例外メッセージボックス
Word でフィールド更新しても相互参照が更新されない
Visual Studio で保存時にコードを自動整形する
TortoiseGit で SubTree を使用する
[C#] Math.Round で四捨五入
[C#] Cryptowatch API で取得した JSON をデシリアライズする
►
9月
(6)
►
8月
(10)
►
7月
(10)
►
6月
(8)
►
5月
(9)
►
4月
(8)
►
3月
(14)
►
2月
(4)
►
1月
(11)
►
2017
(117)
►
12月
(14)
►
11月
(20)
►
10月
(17)
►
9月
(19)
►
8月
(10)
►
7月
(8)
►
6月
(3)
►
5月
(6)
►
4月
(5)
►
3月
(2)
►
2月
(8)
►
1月
(5)
►
2016
(91)
►
12月
(5)
►
11月
(9)
►
10月
(11)
►
9月
(9)
►
8月
(6)
►
7月
(14)
►
6月
(14)
►
5月
(11)
►
4月
(10)
►
3月
(2)
►
2015
(23)
►
12月
(4)
►
11月
(2)
►
10月
(8)
►
9月
(8)
►
7月
(1)
►
2013
(3)
►
11月
(1)
►
9月
(1)
►
7月
(1)
►
2012
(2)
►
7月
(1)
►
6月
(1)
►
2011
(1)
►
9月
(1)
►
2009
(1)
►
7月
(1)
►
2008
(2)
►
11月
(1)
►
7月
(1)
►
2007
(3)
►
10月
(3)