小编luc*_*mia的帖子

sqlite3选择min,max一起比单独选择它们慢得多

sqlite> explain query plan select max(utc_time) from RequestLog;
0|0|0|SEARCH TABLE RequestLog USING COVERING INDEX key (~1 rows) # very fast

sqlite> explain query plan select min(utc_time) from RequestLog;
0|0|0|SEARCH TABLE RequestLog USING COVERING INDEX key (~1 rows) # very fast

sqlite> explain query plan select min(utc_time), max(utc_time) from RequestLog;
0|0|0|SCAN TABLE RequestLog (~8768261 rows) # will be very very slow
Run Code Online (Sandbox Code Playgroud)

虽然我使用minmax独立,它完美的作品.但是,sqlite会因为某些原因选择minmax一起时"忘记"索引.有没有我可以做的配置(我Analyze已经使用过,它不起作用)?或者这种行为有什么解释吗?

EDIT1

sqlite> .schema 

CREATE TABLE FixLog(
                    app_id text,  __key__id …
Run Code Online (Sandbox Code Playgroud)

sql sqlite sql-execution-plan

6
推荐指数
1
解决办法
5094
查看次数

无论大小写差异如何,都在python中匹配字符串

我正在尝试使用python从关键字中找到匹配值.我的值存储在list(my_list)中,在下面的例子中我试图找到'Webcam'这个词.如果它完全匹配,我只想返回这个词.

使用item.find可以工作,但仅在大小写匹配时(即大写和小写必须正确).但是我想要返回该项目,无论如何,但是,我不希望匹配像'Webcamnew'这样的字符串的所有实例,所以使用any()方法将无法工作.有谁知道如何做到这一点..?

my_list = ['webcam', 'home', 'Space', 'Maybe later', 'Webcamnew']

for item in my_list:
    if item.find("Webcam") != -1:
        print item
Run Code Online (Sandbox Code Playgroud)

python

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

使用C#属性来跟踪函数调用,变量和返回值?

在Python中,我可以使用装饰器来跟踪函数调用,它的变量和返回值.这是非常容易使用.我只是想知道C#可以做同样的事情吗?

我发现在线有一个CallTracing属性的示例代码.但是,它没有显示我预期的结果.

C#属性是否与python的装饰器具有相似的概念?

谢谢你和最诚挚的问候!

[AttributeUsage(AttributeTargets.Method | AttributeTargets.ReturnValue |
    AttributeTargets.Property, AllowMultiple = false)]
public class CallTracingAttribute : Attribute
{
    public CallTracingAttribute()
    {

        try
        {
            StackTrace stackTrace = new StackTrace();
            StackFrame stackFrame = stackTrace.GetFrame(1);                

            Trace.TraceInformation("{0}->{1} {2}:{3}",
                stackFrame.GetMethod().ReflectedType.Name,
                stackFrame.GetMethod().Name,
                stackFrame.GetFileName(),
                stackFrame.GetFileLineNumber());

            Debug.WriteLine(string.Format("{0}->{1} {2}:{3}",
                stackFrame.GetMethod().ReflectedType.Name,
                stackFrame.GetMethod().Name,
                stackFrame.GetFileName(),
                stackFrame.GetFileLineNumber()));
        }
        catch
        {
        }
    }
}

class Program
{
    [CallTracing]
    static int Test(int a)
    {
        return 0;
    }

    [CallTracing]
    static void Main(string[] args)
    {
        Test(1);
    }
}
Run Code Online (Sandbox Code Playgroud)

c# debugging attributes stack-trace

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

如何收集喜欢粉丝页面中"帖子"的Facebook用户的ID?

我刚刚完成了Facebook比赛活动,并希望邀请所有访问者查看结果.

如果我可以将Facebook页面配置为仅接受粉丝页面上的帖子"粉丝","喜欢"或"评论"的用户,那将会简单得多.

有没有办法收集所有在我的脸书粉丝页面上"喜欢"或"评论"相关"帖子"的Facebook用户?

facebook

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

sqlite将新值插入视图

我想确保我以正确的方式做了一切.

我想分析一个3Gb日志文件.为了在":memory:"中执行所有查询以提高性能,我将10行文本列替换为每行日志的整数ID.

create table if not exists app (
    id Integer primary key autoincrement,
    value text unique
);

create table if not exists secret (
    id integer primary key autoincrement,
    value text unique
);

and 10 more tables

create table if not exists raw_log
(
    id Integer primary key autoincrement,
    app_id INTEGER,
    secret_id INTEGER,
    and 10 more _id columns
 );
Run Code Online (Sandbox Code Playgroud)

并创建查询视图和插入触发器.

create view if not exists log as 
    Select 
        raw_log.id,
        app.value as app,

        secret.value as secret,
        and 10 more ... …
Run Code Online (Sandbox Code Playgroud)

sql sqlite triggers view

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

Google Cloud Datastore的ORM

https://developers.google.com/datastore/docs/overview

它看起来像GAE中的数据存储区,但没有ORM(对象关系模型)。我可以使用与GAE for Cloud Datastore上的数据存储相同的ORM模型吗?或是否可以为Cloud Datastore找到任何ORM支持?

python orm google-cloud-datastore

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

Google App Engine Edge Cache无法正常运行

我根据以下文章设置了google appengine边缘缓存. http://www.xyhd.tv/2011/11/industry-news/setting-cache-control-headers-in-python-to-take-advantage-of-google-appengines-edgecache/

直到最近才完美.我注意到它不再起作用了(日志中的所有请求状态代码变为200而不是204)有没有办法解决它?

更新(2015/7/20)

该错误已得到修复!NICE!

python google-app-engine caching

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

用PIL绘制下划线文本

有一篇与粗体/斜体有关的帖子: 用PIL绘制粗体/斜体文本吗?

但是,如何使用PIL绘制下划线文本?

python underline python-imaging-library

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

使用django模板将json填充到html

为了更好地调试我的api,我想创建一个调试页面,逐行显示响应json obj的所有细节.我认为它可以通过代码或django模板完成.最简单的方法是什么?

https://developers.facebook.com/tools/explorer/?method=GET 例如,facebook explorer确实列出了响应json obj的详细信息.

{
  "id": "xxx", 
  "name": "xxx", 
  "first_name": "xxx", 
  "last_name": "xxx", 
  "link": "xxx", 
  "username": "xxx", 
  "hometown": {
    "id": "xxx", 
    "name": "xxx"
  }, 
  "location": {
    "id": "xxx", 
    "name": "xxx"
  }, 
  "bio": "Drink Coffee in Whitehorse", 

  "work": [
    {
      "employer": {
        "id": "xxx", 
        "name": "xxx"
      }, 
      "location": {
        "id": "xxx", 
        "name": "xxx"
      }, 
      "position": {
        "id": "xxx", 
        "name": "xxx"
      }, 
      "start_date": "2009-01", 
      "end_date": "0000-00"
    }, 
}
Run Code Online (Sandbox Code Playgroud)

python django json django-templates

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

如何提高sqlite中where和group by的查询性能

现在名为 log 的表中大约有 200 万条记录。查询性能变得不可接受,但我不想在当前阶段将表拆分到不同的分区。因此,我尝试添加一些索引以提高查询性能。

CREATE TABLE log
           (
                id Integer primary key autoincrement,
                app_id text,
                __key__id INTEGER,

                secret text,
                trace_code text,
                url text,

                action text,

                facebook_id text,
                ip text,

                tw_time timestamp,
                time timestamp,

                tag text,
                to_url text,

                from_url text,
                referer text,

                weight integer,
                Unique(app_id, __key__id)
            );
CREATE INDEX key1 on log (action, url, tag);
Run Code Online (Sandbox Code Playgroud)

然而,看起来 sqlite 只是忽略我的索引,而是扫描整个表。我错过了什么吗?

sqlite> explain query plan select count(*) from log where action like 'content_%
';
0|0|0|SCAN TABLE log (~1182357 rows)


sqlite> explain query plan …
Run Code Online (Sandbox Code Playgroud)

sqlite indexing group-by where-clause

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

python不会为元组释放内存,不是吗?

根据我读到的这篇文章,看起来不可变的类型可能变得不朽.

http://effbot.org/pyfaq/why-doesnt-python-release-the-memory-when-i-delete-a-large-object.htm

我目前正在努力解决在谷歌应用引擎上运行的我的网络服务的内存使用问题."使用太多元组"可能是导致此问题的潜在原因吗?


感谢您的回复:我在谷歌应用引擎后端实例上运行我的代码,它有一个内存使用上限(128mb).它说我使用的内存比允许的多,并且停止了我的实例.正如评论所提到的,它可能是"内存使用量仍然很大"而不是"内存泄漏".

python google-app-engine memory-leaks tuples backend

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

如何替换 cloudbuild.yaml 中的替换字符串

如何替换 cloudbuild.yaml 中的替换字符串?

我想使用 cloudbuild 将 appengine 版本设置为 $TAG_NAME。由于该版本仅接受连字符,因此我需要先将点替换为连字符。

我试过:

steps:
- name: 'gcr.io/cloud-builders/gcloud'
  args: ['app', 'deploy', '--no-promote', "--version=$(echo $TAG_NAME | sed 's/[.]/-/g')"]
timeout: '1600s'
Run Code Online (Sandbox Code Playgroud)

但得到了

ERROR: (gcloud.app.deploy) argument --version/-v: Bad value [$(echo 0.0.1a4 | sed 's/[.]/-/g')]: May only contain lowercase letters, digits, and hyphens. Must begin and end with a letter or digit. Must not exceed 63 characters.
Run Code Online (Sandbox Code Playgroud)

bash google-app-engine google-cloud-build

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

1366 mysql 不正确的注音符号字符串值

“不正确的字符串值错误”是从 MySQLdb 引发的。

_mysql_exceptions.OperationalError: (1366, "Incorrect string value: '\\xF0\\xA0\
\x84\\x8E\\xE2\\x8B...' for column 'from_url' at row 1")
Run Code Online (Sandbox Code Playgroud)

但是我已经将连接字符集和从 url 编码设置为 utf8。对于数百万以前的记录,它可以毫无问题地工作。

将导致异常的值:我认为问题与特殊字符 u'\U0002010e' (中文特殊字符“?”)有关

u'http://www.ettoday.net/news/20120227/27879.htm?fb_action_ids=305328666231772&
fb_action_types=og.likes&fb_source=aggregation&fb_aggregation_id=288381481237582
 \u7c89\u53ef\u611b\U0002010e\u22ef http://www.ettoday.net/news/20120221/26254.h
tm?fb_action_ids=305330026231636&fb_action_types=og.likes&fb_source=aggregation&
fb_aggregation_id=288381481237582 \u597d\u840c\u53c8\u22ef'
Run Code Online (Sandbox Code Playgroud)

但是这个字符也可以在python中编码为utf8。

>>> u'\U0002010e'.encode('utf8')
'\xf0\xa0\x84\x8e'
Run Code Online (Sandbox Code Playgroud)

那么为什么 MySQL 不能接受这个字符呢?

python mysql utf-8 mysql-python

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