json file schema / object для запуска схемы для загрузки данных

Поскольку этот поток наткнулся, я собрал несколько точек для новых читателей в this.

Как определено значение this?

Мы используем это подобно тому, как мы используем местоимения в естественных языках, таких как английский: «Джон работает быстро, потому что он пытается поймать поезд». Вместо этого мы могли бы написать «... Джон пытается поймать поезд ».

var person = {    
    firstName: "Penelope",
    lastName: "Barrymore",
    fullName: function () {

    // We use "this" just as in the sentence above:
       console.log(this.firstName + " " + this.lastName);

    // We could have also written:
       console.log(person.firstName + " " + person.lastName);
    }
}

this не присваивается значение, пока объект не вызовет функцию, в которой он определен. В глобальной области действия все глобальные переменные и функции определяются на объекте window. Следовательно, this в глобальной функции относится к (и имеет значение) глобальный объект window.

Когда use strict, this в глобальном и в анонимных функциях, не связанных с каким-либо объектом, имеет значение undefined.

Ключевое слово this g0] наиболее непонятно , когда: 1) мы используем метод, который использует this, 2) мы назначаем метод, который использует this для переменной, 3) функция, которая использует this, передается как функция обратного вызова и 4) this используется внутри замыкания - внутренней функции. (2)

table [/g10]

Что содержит будущее

Определено в сценарии ECMA 6 , стрелка- функции принимают привязку this из охватывающей (функциональной или глобальной) области.

function foo() {
     // return an arrow function
     return (a) => {
     // `this` here is lexically inherited from `foo()`
     console.log(this.a);
  };
}
var obj1 = { a: 2 };
var obj2 = { a: 3 };

var bar = foo.call(obj1);
bar.call( obj2 ); // 2, not 3!

Хотя функции-стрелки предоставляют альтернативу использованию bind(), важно отметить, что они по существу отключают традиционный механизм this в пользу более широкого понимания лексического охвата. (1)


Ссылки:

  1. this & amp; Object Prototypes, автор Kyle Simpson. © 2014 Getify Solutions.
  2. javascriptissexy.com - http://goo.gl/pvl0GX
  3. Ангус Кролл - http: // goo .gl / Z2RacU

0
задан Adas Kavaliauskas 13 July 2018 в 16:37
поделиться

1 ответ

Вы говорите, что они выходят из строя, но это потому, что у python dicts нет порядка (кроме самых последних версий).

Вместо этого вы можете использовать OrderedDict, и они сохранят исходный порядок :

from collections import OrderedDict
data = json.loads(my_json, object_pairs_hook=OrderedDict)
0
ответ дан nosklo 17 August 2018 в 12:23
поделиться
  • 1
    То, что я имею в виду, говоря, что вышло из строя, заключается в том, что, когда данные загружаются в улей, например, данные, которые должны быть в столбце 1, относятся к тому, почему используется другой столбец. Я передаю все данные прямо, чтобы искривить фрейм данных, и кажется, что имя столбца упорядочено так, что оно отличается от последовательности, чем в файле. Вот почему я хочу создать схему, которую я бы хотел передать при загрузке данных, чтобы сохранить все на месте в улье. – Adas Kavaliauskas 13 July 2018 в 16:53
  • 2
    @AdasKavaliauskas, как вы загружаете данные в куст? Вы пытались использовать OrderedDicts, и это не сработало? – nosklo 13 July 2018 в 17:07
  • 3
    Нет, я не пробовал OrderedDicts. Я читаю json с помощью SparkContext, чтобы создать dataframe, а затем писать в улей. Должен ли сначала использовать json.loads? – Adas Kavaliauskas 13 July 2018 в 17:14
Другие вопросы по тегам:

Похожие вопросы: