質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.47%

  • JavaScript

    17065questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

JavaScriptで文字列を配列に変換する方法

解決済

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 540

EzrealTrueshot

score 373

文字列を配列にする方法をご存知のかたいらっしゃいましたらご教示頂けませんでしょうか?

aaa = {success: "['2017-12-08 13:57','2017-12-08 13:56','2017-12-08 13:55']"}


上記を typeof 出力すると obejct と表示されます。

aaa['success']をconsole.logすると

['2017-12-08 13:57','2017-12-08 13:56','2017-12-08 13:55']


これを typeof 出力すると string と表示されます。


配列なので object として返ってくると思っていたのですが、stringとして返ってきます。
このあとの処理で配列として処理させたいので、このままでは非常に困ります。

そこで、文字列として書かれている配列を本当の配列として変換する方法がありましたら教えていただけないでしょうか?

*備考
pythonで恐縮ですが
int(hoge)  -->  int型に変換
str(hoge)  -->  str型に変換

こんな感じで

配列(hoge)  -->  配列型に変換

とかJavascriptでできたらうれしいです。

1行でできなくてもいいので、文字列として書かれている配列を本当の配列として変換する方法さえあれば幸いです。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+6

文字列部分は['2017-12-08 13:57','2017-12-08 13:56','2017-12-08 13:55']ですね。これはJSON形式で書かれているようです。ですので、JSONをパースする処理を使えば配列に変換できます。

var array = JSON.parse(aaa['success']);
console.log(array[0]); // '2017-12-08 13:57'
console.log(array[1]); // '2017-12-08 13:56'
console.log(array[2]); // '2017-12-08 13:55'

追記

JSONはシングルクォーテーション'を認識してくれない仕様らしいので、置き換えて問題なさそうなら'"に置き換えてJSON.parseしてしまいましょう。

var array = JSON.parse(aaa['success'].replace(/'/g, '"'));

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/12/08 15:47

    回答ありがとうございます!

    Uncaught SyntaxError: Unexpected token ' in JSON at position 1

    このような結果になってしまいました。

    キャンセル

  • 2017/12/08 15:48

    ちなみに
    console.log(array[0]);
    この結果は
    [
    ↑カギカッコのはじまり1つになっています。

    キャンセル

  • 2017/12/08 15:51

    私も知らなかったので衝撃を受けていますが、JSON形式はシングルクォーテーションを認識しないようです…この配列は日付日時しか入っていない想定ですか?

    キャンセル

  • 2017/12/08 15:55

    はい、日付日時しか入りません!

    キャンセル

  • 2017/12/08 15:56

    でしたら回答の追記のように'を"に置き換えたら問題解決です。

    キャンセル

  • 2017/12/08 16:19

    ありがとうございます!
    シングルクォーテーションをダブルクオーテーションに置換させたところ、無事解決しました。

    キャンセル

  • 2017/12/08 16:22

    もしこのレスポンスを返す実装をした人が身近な人であれば、「JSONのつもりだったらエラーになるからシングルクォーテーションをダブルクォーテーションに直して」と伝えてあげるほうが今後のためになるかと思います。今回は'が内容に影響しない日付だったからこそ'を"に置き換えるという力技が通りましたが、本来であればデータのほうを正すべきです。

    キャンセル

  • 2017/12/08 22:42

    横レスから失礼します。仕様が気になったのでRFCを当たってみました。仕様上はダブルクォーテーションしか受け付けないみたいです。
    □The JavaScript Object Notation (JSON) Data Interchange Format
    https://tools.ietf.org/html/rfc7159
    string = quotation-mark *char quotation-mark
    quotation-mark = %x22 ; "

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.47%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    [数値と文字列の判断方法]

    渡ってきたデータを変数へ格納し、それを使用する際、   文字列として渡ってきたのか数値として渡ってきたのかを   確認する方法はありますでしょうか?   数値で渡ってきた

  • 受付中

    未経験者にnullと0の違いを説明する方法

    新人にjavascriptを教えている最中ですが、 nullと0の違いがなかなか理解できないみたいです。 まったくのプログラム未経験者に伝えるにはどのように伝えれば Null

  • 解決済

    JavaScriptの構文

    JavaScript勉強中のものです。 すごく基本的なことを聞いてしまいますが、 下記の構文は、どういう意味があるのでしょうか? ソースコード var hoge; (fun

  • 解決済

    [node-red][javascript]オブジェクトの存在確認チェックが出来ない

    node-redを使い、postされたデータを受け取りjson項目の存在チェックを行うfunctionを記述しています。 下記json項目の中で、department_idが存在す

  • 解決済

    変数を動的に生成したい(IE11対応)

    先日ご質問させていただいた、以下について https://teratail.com/questions/118802 IE11がArray.from未対応で使えないことが発覚し

  • 解決済

    jqueryの同じ処理をするコードのまとめ方

     前提・実現したいこと 選択された要素を非表示にし、それをcookieを使い保存しています。 これらの処理をまとめるにはどの様にすればよいのでしょうか? よろしくお願いします。

  • 解決済

    hoge()[]←これがわかりません。

    hoge()()も知らなかったのですが、これは調べたら出てきました。しかし、hoge()[]の意味がどうしても出てきません。ソースは以下です。 URL:http://jsfid

  • 受付中

    Javascriptの正規表現(否定の記述)でつまづいてるので教えてください

     前提・実現したいこと Javascriptの正規表現で文字列を取得したい。  発生している問題・エラーメッセージ ① http://aaa.jpg ⓶ http://aa

同じタグがついた質問を見る

  • JavaScript

    17065questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。