Создайте новую запись (кадр данных) и добавьте в old_data_frame. передать список значений и соответствующие им имена столбцов для создания new_record (data_frame)
new_record = pd.DataFrame([[0,'abcd',0,1,123]],columns=['a','b','c','d','e'])
old_data_frame = pd.concat([old_data_frame,new_record])
Вы не можете.
В JavaScript нет восходящих отношений.
Возьмем, например:
var foo = {
bar: [1,2,3]
}
var baz = {};
baz.bar = foo.bar;
Объект одиночного массива теперь имеет двух «родителей».
Что вы можете сделать, это что-то вроде:
var User = function User(name) {
this.name = name;
};
User.prototype = {};
User.prototype.ShowGreetings = function () {
alert(this.name);
};
var user = new User('For Example');
user.ShowGreetings();
// Make user global
window.user = {
name: "Some user",
methods: {
showGreetings: function () {
window.alert("Hello " + this.getUserName());
},
getUserName: function () {
return this.getParent().name;
}
}
};
// Add some JavaScript magic
(function () {
var makeClass = function (className) {
createClass.call(this, className);
for (key in this[className]) {
if (typeof this[className][key] === "object") {
makeClass.call(this[className], key);
}
}
}
var createClass = function (className) {
// private
var _parent = this;
var _namespace = className;
// public
this[className] = this[className] || {};
this[className].getType = function () {
var o = this,
ret = "";
while (typeof o.getParent === "function") {
ret = o.getNamespace() + (ret.length === 0 ? "" : ".") + ret;
o = o.getParent();
}
return ret;
};
this[className].getParent = function () {
return _parent;
};
this[className].getNamespace = function () {
return _namespace;
}
};
makeClass.call(window, "user");
})();
user.methods.showGreetings();
Давид Дорвард прямо здесь. Самое простое решение, tho, было бы получить доступ к user.Name
, так как user
эффективно является одиночным.
Как говорили другие, с простым объектом невозможно найти родителя из вложенного дочернего элемента.
Однако, если вы используете рекурсивные ES6 Proxies в качестве помощников.
Я написал библиотеку с именем ObservableSlim что, между прочим, позволяет переходить от дочернего объекта к родительскому.
Вот простой пример ( jsFiddle demo ):
var test = {"hello":{"foo":{"bar":"world"}}};
var proxy = ObservableSlim.create(test, true, function() { return false });
function traverseUp(childObj) {
console.log(JSON.stringify(childObj.__getParent())); // returns test.hello: {"foo":{"bar":"world"}}
console.log(childObj.__getParent(2)); // attempts to traverse up two levels, returns undefined because test.hello does not have a parent object
};
traverseUp(proxy.hello.foo);
Я столкнулся с этим старым сообщением, пытаясь вспомнить, как решить проблему. Вот решение, которое я использовал. Это происходит из шаблонов проектирования JavaScript по шаблонам Harmes и Diaz (Apress 2008) на стр. 8. Вам нужно объявить функцию, а затем создать новый экземпляр, как показано ниже. Обратите внимание, что метод Store может получить доступ к «этому».
function Test() {
this.x = 1;
}
Test.prototype = {
Store: function (y) { this.x = y; },
}
var t1 = new Test();
var t2 = new Test();
t1.Store(3);
t2.Store(5);
console.log(t1);
console.log(t2);
Вы можете попробовать другой подход, используя закрытие:
function userFn(name){
return {
Methods: {
ShowGreetings: function() {
alert(name);
}
}
}
}
var user = new userFn('some user');
user.Methods.ShowGreetings();
var user = {
Name: "Some user",
Methods: {
ShowGreetings: function() {
alert(this.Parent.Name); // "this" is the Methods object
},
GetUserName: function() { }
},
Init: function() {
this.Methods.Parent = this; // it allows the Methods object to know who its Parent is
delete this.Init; // if you don't need the Init method anymore after the you instanced the object you can remove it
return this; // it gives back the object itself to instance it
}
}.Init();
«Привилегированный метод имеет доступ к частным переменным и методам и сам доступен для общедоступных методов и снаружи»
blockquote>Например:
function user(name) { var username = name; this.showGreetings = function() { alert(username); } }
Как насчет этого пути?
user.Methods.ShowGreetings.call(user, args);
Таким образом, вы можете получить доступ к user.Name в ShowGreetings
var user = {
Name: "Some user",
Methods: {
ShowGreetings: function(arg) {
console.log(arg, this.Name);
},
GetUserName: function() { }
},
Init: function() {
this.Methods.ShowGreetings.call(this, 1);
}
};
user.Init(); // => 1 "Some user"
Старый вопрос, но почему вы не можете просто сделать что-то вроде этого:
var user = {
Name: "Some user",
Methods: {
ShowGreetings: function() {
// at this point i want to access variable "Name",
//i dont want to use user.Name
// **please suggest me how??**
var thisName = user.Name; //<<<<<<<<<
},
GetUserName: function() { }
}
}
Потому что вы будете вызывать только user.Methods.ShowGreetings () после того, как пользователь был создан. Значит, вы узнаете о переменной «пользователь», когда хотите использовать ее имя?