小编Try*_*ass的帖子

DOM replaceChild不替换所有指定的元素

请考虑以下代码:

$xml = <<<XML
<root>
<region id='thisRegion'></region>
<region id='thatRegion'></region>
</root>
XML;
Run Code Online (Sandbox Code Playgroud)
$partials['thisRegion'] = "<p>Here's this region</p>";
$partials['thatRegion'] = "<p>Here's that region</p>";
$DOM = new DOMDocument;
$DOM->loadXML($xml);

$regions = $DOM->getElementsByTagname('region');

foreach( $regions as $region )
{
    $id = $region->getAttribute('id');
    $partial = $DOM->createDocumentFragment();
    $partial->appendXML( $partials[$id] );
    $region->parentNode->replaceChild($partial, $region);

}

echo $DOM->saveXML();
Run Code Online (Sandbox Code Playgroud)

输出是:

<root>
<p>Here's this region</p>
<region id="thatRegion"/>
</root>
Run Code Online (Sandbox Code Playgroud)

我不能为我的生活弄清楚为什么所有的区域标签都没有被替换.这是我的项目中的一个问题,起初我认为它并没有替换我在loadXML之后附加的元素,但是通过一些实验,我无法在这里缩小模式.

我希望代码更正,以允许我用给定的元素节点替换DOMDocument中的所有标签.如果我没有找到它,我也不介意任何输入更有效/实用的方法来执行它.

提前致谢!

[编辑] PHP 5.3.13

php domdocument

5
推荐指数
1
解决办法
1810
查看次数

修改SqlAlchemy模型时出现Unhashable Type错误

我正在使用实际上是从文档复制而来的最基本的烧瓶应用程序,并且收到了一个非常烦人的错误。我已经能够找到它,但不知道如何解决。我知道在实现flask-security时会出现问题,但错误来自sqlalchemy内部。有什么建议吗?

from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy
import logging
app = Flask(__name__)

app.config['DEBUG'] = True
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///:memory:' #

db = SQLAlchemy(app)

roles_users = db.Table('roles_users',
        db.Column('user_id', db.Integer(), db.ForeignKey('user.id')),
        db.Column('role_id', db.Integer(), db.ForeignKey('role.id')))

class Role(db.Model):
    id = db.Column(db.Integer(), primary_key=True)
    name = db.Column(db.String(80), unique=True)
    description = db.Column(db.String(255))

    def __init__(self, name, desc):
        self.name = name 
        self.description = desc

    def __repr__(self):
        return '<Role: {}>'.format(str(self.name))

class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(255), unique=True)
    password = db.Column(db.String(255))
    roles = db.relationship('Role', secondary=roles_users,
                            backref=db.backref('users', lazy='dynamic')) …
Run Code Online (Sandbox Code Playgroud)

python flask flask-sqlalchemy flask-security

2
推荐指数
1
解决办法
2398
查看次数