小编Mar*_*cin的帖子

如何在Celery中检查任务状态?

如何检查任务是否在芹菜中运行(具体来说,我使用的是celery-django)?

我已经阅读了文档,而且我用谷歌搜索了,但我看不到像这样的电话:

my_example_task.state() == RUNNING
Run Code Online (Sandbox Code Playgroud)

我的用例是我有一个用于转码的外部(java)服务.当我发送要转码的文档时,我想检查运行该服务的任务是否正在运行,如果没有,则(重新)启动它.

我正在使用目前的稳定版本 - 2.4,我相信.

python web-services celery django-celery

85
推荐指数
7
解决办法
9万
查看次数

在SVG中嵌入SVG?

我有一个SVG文档,我想在其中包含一个外部svg图像,例如:

<object data="logo.svgz" width="100" height="100" x="200" y="400"/>
Run Code Online (Sandbox Code Playgroud)

("对象"只是一个例子 - 外部文档将是SVG而不是xhtml).

有任何想法吗?这甚至可能吗?或者对我来说最简单的方法是将logo.svg xml打到我的外部SVG文件中?

xml svg embedding

80
推荐指数
6
解决办法
7万
查看次数

如何获取SQLAlchemy对象的主键名称?

我只想以编程方式确定SQLalchemy模型的主键名称.

sqlalchemy

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

python中子进程读取线上的超时

我有一个小问题,我不太确定如何解决.这是一个最小的例子:

是)我有的

scan_process = subprocess.Popen(command, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
while(some_criterium):
    line = scan_process.stdout.readline()
    some_criterium = do_something(line)
Run Code Online (Sandbox Code Playgroud)

我想要什么

scan_process = subprocess.Popen(command, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
while(some_criterium):
    line = scan_process.stdout.readline()
    if nothing_happens_after_10s:
        break
    else:
        some_criterium = do_something(line)
Run Code Online (Sandbox Code Playgroud)

我从子进程读取一行并用它做一些事情.我想要的是在固定时间间隔后没有线路到达时退出.有什么建议?

python subprocess timeout

39
推荐指数
5
解决办法
3万
查看次数

Python十进制到字符串

这里有很多主题可以解释如何将字符串转换为小数,但是如何将小数转换回字符串?

就像我这样做:

import decimal
dec = decimal.Decimal('10.0')
Run Code Online (Sandbox Code Playgroud)

我怎么拿出dec'10.0'(一根绳子)?

python string decimal

37
推荐指数
3
解决办法
6万
查看次数

为什么Python新样式类中的__new__不是类方法?

Python 2.2的Changelog(引入了新式类)说明了关于该__new__函数的以下内容:

__new__是一个静态方法,而不是类方法.我最初认为它必须是一个类方法,这就是我添加classmethod原语的原因.不幸的是,使用类方法,upcalls在这种情况下不能正常工作,因此我不得不将它作为静态方法,并将显式类作为其第一个参数.

但是,我无法想到为什么类方法不能用于此目的,它肯定会更好看.为什么最终不会__new__以类方法结束?当Guido说"在这种情况下上调不能正常工作"时,Guido会提到什么?

python language-design new-operator new-style-class

35
推荐指数
1
解决办法
1957
查看次数

泰国破线:如何有效打破泰国文本

在客户端站点上使用泰语文本的情况是我们无法控制特定单词/句子在行之间断开的位置(Web浏览器将如何处理它).通常,本地审阅者表示内容外观不正确.

解决 这个问题的方法是,撰稿人需要提供包含破坏&#8203;和不间断的&#65279;零宽度空间字符的泰语内容.

在实践中,而不是:
?????????? ??????????????
我们应该使用丑陋的东西:
?&#65279;?&#65279;?&#65279;?&#65279;???&#65279;?&#65279;?&#65279;?&#8203;???&#8203;?&#65279;?&#65279;?&#65279;?&#65279;?&#65279;??&#65279;?&#65279;???

以上只是一个例子,我真的不知道断点的确切位置.
实际上,单独的非零破坏空间也可以做到这一点......使用破碎的零空间以及更高的准确性更加严格和正确.

虽然它确实是可行的,但它对于大型网站内容管理来说也是一个耗时且不是非常有效的解决方案.简单地说,投入的努力与所需的效果不相符.

到目前为止的研究已经导致了所提到的解决方法,寻找更好的方法来处理这个问题.甚至W3C还没有解决方案,只是讨论它是否应该成为CSS3规范的一部分.

泰语很少使用空间,主要用于区分句子等.因此,泰语句子的常见外观是一个looong字符串.当更多行文本放在一起时,在哪里打破这样的字符串由特定的单词标识确定.对于单词识别,使用本地词典,这些词典很可能是操作系统或Web浏览器的一部分,我不完全确定这些.

显然,您检查的Web浏览器/操作系统越多,您获得的结果就越多!此外,由于它是系统驱动的,并且没有"在哪里打破泰国"设置,因此您无法做到这一点.

使用<wbr/>,&#8203;&shy;以指示断点真的是不会阻止的网页浏览器的思想(即使是错误的),一些休息也是可能的地方,在这里你还没有一个字的中间定义他们如这可能是语法上不正确.

如果将这样的单词放在一行的末尾(取决于屏幕分辨率,复制长度,定义的CSS规则),并且浏览器在其上应用了错误的换行规则,那么最终会出现泰语断行问题,无论如何你已经在单词之前,之后或其他地方定义了另一个断点 - 浏览器将始终使用他认为最接近EOL的断点,而不仅仅是你通过在标记中插入一个提到的字符而轻轻建议的断点.

这就是为什么你真的需要专注于不打破文本的地方(不打破零宽度空间),而不是它允许的地方.这就是我们回到上面"解决方法"部分中的丑陋和长标记示例的原因.这样一个换行符只能在你允许它的地方发生,但它很麻烦.

任何其他解决方案 如何更有效地处理这一点将不胜感激......谁知道,它甚至可能帮助W3C实施?

谢谢!

html css unicode internationalization browser-bugs

28
推荐指数
1
解决办法
1万
查看次数

在django中管理数据库迁移的最佳解决方案是什么?

我非常喜欢Rails的数据库迁移管理系统.它不是100%完美,但它可以做到这一点.Django没有附带这样的数据库迁移系统(但是?)但是有很多开源项目可以做到这一点,例如django-evolution和south.

所以我想知道,您更喜欢django的数据库迁移管理解决方案?(每个答案一个选项请)

python database django data-migration schema-migration

26
推荐指数
3
解决办法
1万
查看次数

在django测试期间加载夹具时的IntegrityError

我正在加载使用dumpdata创建的fixture,并获得以下异常:

Problem installing fixture 'db_dump.json': Traceback (most recent call last):
  File "/usr/lib/python2.6/site-packages/django/core/management/commands/loaddata.py", line 174, in handle
    obj.save(using=using)
  File "/usr/lib/python2.6/site-packages/django/core/serializers/base.py", line 165, in save
    models.Model.save_base(self.object, using=using, raw=True)
  File "/usr/lib/python2.6/site-packages/django/db/models/base.py", line 526, in save_base
    rows = manager.using(using).filter(pk=pk_val)._update(values)
  File "/usr/lib/python2.6/site-packages/django/db/models/query.py", line 491, in _update
    return query.get_compiler(self.db).execute_sql(None)
  File "/usr/lib/python2.6/site-packages/django/db/models/sql/compiler.py", line 869, in execute_sql
    cursor = super(SQLUpdateCompiler, self).execute_sql(result_type)
  File "/usr/lib/python2.6/site-packages/django/db/models/sql/compiler.py", line 735, in execute_sql
    cursor.execute(sql, params)
  File "/usr/lib/python2.6/site-packages/django/db/backends/sqlite3/base.py", line 234, in execute
    return Database.Cursor.execute(self, query, params)
IntegrityError: columns app_label, model are not unique
Run Code Online (Sandbox Code Playgroud)

这是一个sqlite3后端.

更新:使用自然键在这里没有区别. …

django django-testing django-fixtures

24
推荐指数
2
解决办法
6902
查看次数

为什么Python列表添加必须是同质的?

任何熟悉Python内部(CPython或其他实现)的人都可以解释为什么列表添加需要是同质的:

In [1]: x = [1]

In [2]: x+"foo"
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
C:\Users\Marcin\<ipython-input-2-94cd84126ddc> in <module>()
----> 1 x+"foo"

TypeError: can only concatenate list (not "str") to list

In [3]: x+="foo"

In [4]: x
Out[4]: [1, 'f', 'o', 'o']
Run Code Online (Sandbox Code Playgroud)

为什么x+"foo"以上不会返回与x上述成绩单中的最终值相同的值?

这个问题来自NPE的问题:Python列表+ = iterable的行为是否记录在何处?

更新:我知道不需要异质+=工作(但确实如此),同样,并不要求异质+是错误.这个问题是为什么做出后一种选择.

很难说将序列添加到列表中的结果是不确定的.如果这是一个充分的反对意见,那么防止异质性是有意义的+=.Update2:特别是,python总是将操作符调用委托给左侧操作数,因此没有问题出现"什么是正确的事情"":左手对象总是管理(除非它委托到右边).

更新3:对于任何人认为这是一个设计决定,请解释(a)为什么没有记录; 或(b)如有文件记录.

Update4:"应该[1] + (2, )返回什么?" 它应该返回一个结果值,该值等于x最初[1]紧跟在之后的变量的值x+=(2, ).这个结果定义明确.

python language-design language-implementation python-internals

24
推荐指数
2
解决办法
817
查看次数