Vic*_*ciu 4 python unicode sqlalchemy
使用SQLAlchemy将对象插入数据库时,与String()列对应的所有属性都会自动从<type'str'>转换为<type'unicode'>.有没有办法防止这种行为?
这是代码:
from sqlalchemy import create_engine, Table, Column, Integer, String, MetaData
from sqlalchemy.orm import mapper, sessionmaker
engine = create_engine('sqlite:///:memory:', echo=False)
metadata = MetaData()
table = Table('projects', metadata,
Column('id', Integer, primary_key=True),
Column('name', String(50))
)
class Project(object):
def __init__(self, name):
self.name = name
mapper(Project, table)
metadata.create_all(engine)
session = sessionmaker(bind=engine)()
project = Project("Lorem ipsum")
print(type(project.name))
session.add(project)
session.commit()
print(type(project.name))
Run Code Online (Sandbox Code Playgroud)
这是输出:
<type 'str'>
<type 'unicode'>
Run Code Online (Sandbox Code Playgroud)
我知道我应该只使用unicode,但这将涉及挖掘一些第三方代码而我还没有Python技能:)
zif*_*fot 12
实际上,有一种方法可以做到这一点.只需在创建引擎后执行以下代码行:
engine.raw_connection().connection.text_factory = str
不幸的是,你运气不好,这似乎没有用sqlite.SQLAlchemy引用0.6.2文档 - SQLite - Unicode:
与SQLAlchemy对pysqlite的日期和时间类型的主动处理相反,pysqlite关于Unicode的默认行为是所有字符串在所有情况下都作为Python unicode对象返回.因此,即使未使用Unicode类型,您仍将始终从结果集中接收unicode数据.强烈建议您使用Unicode类型来表示字符串,因为如果从用户应用程序传递非unicode Python字符串,它将引发警告.将非unicode对象的使用与返回的unicode对象混合会很快造成混淆,特别是在使用ORM时,因为内部数据并不总是由实际的数据库结果字符串表示.
| 归档时间: |
|
| 查看次数: |
6873 次 |
| 最近记录: |