當前位置: 首頁>>代碼示例>>Python>>正文


Python Method.getCityShopsCode方法代碼示例

本文整理匯總了Python中sellcard.common.Method.getCityShopsCode方法的典型用法代碼示例。如果您正苦於以下問題:Python Method.getCityShopsCode方法的具體用法?Python Method.getCityShopsCode怎麽用?Python Method.getCityShopsCode使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在sellcard.common.Method的用法示例。


在下文中一共展示了Method.getCityShopsCode方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: index

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def index(request):
    role_id = request.session.get('s_roleid')
    shop = request.session.get('s_shopcode')
    role = request.session.get('s_roleid')
    user = request.session.get('s_uid')

    if request.method == 'POST':
        start = request.POST.get('start', '')
        end = request.POST.get('end', '')
        endTime = datetime.datetime.strptime(end, '%Y-%m-%d').date() + datetime.timedelta(1)
        whereStr = "WHERE t.shopcode = s.shop_code AND t.add_time >='" + start + "' AND t.add_time <='" + str(endTime) + "' "

        if role in ('2', '10'):
            whereStr += " AND t.shopcode ='" + shop + "'"
        conn = mth.getMysqlConn()
        cur = conn.cursor()

        shopsCode = ''
        if role_id == '9':
            shopsCode = mth.getCityShopsCode('T')
            shopsCodeStr = "'" + "','".join(shopsCode) + "'"
            whereStr += " AND t.shopcode IN (" + shopsCodeStr + ")"
        if role_id == '8':
            shopsCode = mth.getCityShopsCode('C')
            shopsCodeStr = "'" + "','".join(shopsCode) + "'"
            whereStr += " AND t.shopcode IN (" + shopsCodeStr + ")"

        sql = """
    SELECT
    	date_format(
    		t.add_time,
    		'%Y年%m月%d日'
    	) AS create_date,
    	s.shop_name,
    	t.order_sn,
    	t.borrow_depart,
    	t.order_val * t.order_num AS borrow_account,
    	IFNULL(o.total_amount, 0) AS balance,
    	IFNULL(o.paid_amount, 0) AS actual,
    	IFNULL(o.discount_rate, 0) AS voucher,
    	t.paid_time
    FROM
    	order_borrow t
    LEFT JOIN orders o ON t.reply_order = o.order_sn,
     shops s """ + whereStr + """
    ORDER BY
    	create_date,
    	s.shop_name
            """
        cur.execute(sql)
        List = cur.fetchall()

        borrow_total = 0.00
        balance_total = 0.00
        actual_total = 0.00
        for row in List:
            borrow_total += float(row['borrow_account'])
            balance_total += float(row['balance'])
            actual_total += float(row['actual'])
    return render(request, 'report/finance/borrowCard.html', locals())
開發者ID:KGPython,項目名稱:kggroup,代碼行數:62,代碼來源:borrowCard.py

示例2: index

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def index(request):
    role_id = request.session.get('s_roleid')
    shop_code = request.session.get('s_shopcode')

    kwargs = {}
    kwargs.setdefault('card_status','1')
    kwargs.setdefault('card_action','1')
    kwargs.setdefault('card_blance__gt','0')
    if role_id in ('2','10'):
        kwargs.setdefault('shop_code',shop_code)
    if role_id == '9':
        shops_code = mth.getCityShopsCode('T')
        kwargs.setdefault('shop_code__in', shops_code)
    if role_id == '8':
        shops_code = mth.getCityShopsCode('C')
        kwargs.setdefault('shop_code__in', shops_code)

    cardList = CardInventory.objects\
            .values('shop_code')\
            .filter(**kwargs)\
            .exclude(shop_code='')\
            .annotate(num=Count('card_no'),balance=Sum('card_blance'))\
            .order_by('shop_code')

    totalBalance = 0.00
    totalNum = 0
    for row in cardList:
        totalBalance += float(row['balance'])
        totalNum +=row['num']
    return render(request, 'report/card/stock/stock.html', locals())
開發者ID:KGPython,項目名稱:kggroup,代碼行數:32,代碼來源:stock.py

示例3: index

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def index(request):
    shop = request.session.get('s_shopcode', '')
    role_id = request.session.get('s_roleid')
    if request.method == 'GET':
        start = str(datetime.date.today().replace(day=1))
        end = str(datetime.date.today())
        endTime = str(datetime.date.today() + datetime.timedelta(1))
    if request.method == 'POST':
        today = datetime.date.today()
        start = request.POST.get('start', today)
        end = request.POST.get('end', today)
        endTime = str(datetime.datetime.strptime(end, '%Y-%m-%d').date() + datetime.timedelta(1))

    conn = mth.getMysqlConn()
    cur = conn.cursor()
    if role_id == '1' or role_id == '6':
        shops = mth.getCityShops()
        shopsCode = mth.getCityShopsCode()
    if role_id == '9':
        shops = mth.getCityShops('T')
        shopsCode = mth.getCityShopsCode('T')
    if role_id == '8':
        shops = mth.getCityShops('C')
        shopsCode = mth.getCityShopsCode('C')
    if role_id == '10' or role_id == '2':
        shops = base.findShop(shop)
        shopsCode = [shop]

    shopsCodeStr = "'" + "','".join(shopsCode) + "'"
開發者ID:KGPython,項目名稱:kggroup,代碼行數:31,代碼來源:reimbursement.py

示例4: detail

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def detail(request):
    today = datetime.date.today()
    page = mth.getReqVal(request, 'page', 1)
    shop_code = request.GET.get('shop')
    pay_id = request.GET.get('pay_id')

    shop = request.session.get('s_shopcode', '')
    role_id = request.session.get('s_roleid')
    if role_id == '9':
        shopsCode = mth.getCityShopsCode('T')
        if shop_code not in shopsCode:
            return render(request, '500.html', locals())
    elif role_id == '8':
        shopsCode = mth.getCityShopsCode('C')
        if shop_code not in shopsCode:
            return render(request, '500.html', locals())
    elif role_id == '10' or role_id == '2' or role_id == '12':
        if shop != shop_code:
            return render(request, '500.html', locals())


    start = request.GET.get('start', today)
    end = request.GET.get('end', today)
    endTime = str(datetime.datetime.strptime(end, '%Y-%m-%d').date() + datetime.timedelta(1))

    conn = mth.getMysqlConn()
    cur = conn.cursor()
    if pay_id == '3':
        sql = " select a.order_sn,a.action_type,b.is_pay,b.pay_value,c.bank_name,c.bank_sn,c.pay_company" \
              " from orders as a inner join order_payment_info as b on a.order_sn = b.order_id left join order_payment_credit as c on a.order_sn = c.order_id"\
              " where a.add_time>='{start}' and a.add_time<='{end}' and a.shop_code ='{shop}' and b.pay_id=3" \
              " order by b.is_pay,a.order_sn"\
              .format(start=start, end=endTime, shop=shop_code)
    else:
        sql = " select a.order_sn,a.action_type,a.buyer_name,a.buyer_tel,a.buyer_company,b.pay_value,b.is_pay" \
              " from orders as a ,order_payment_info as b" \
              " where a.order_sn = b.order_id and a.shop_code = '{shop}' and a.add_time >= '{start}'" \
              " and a.add_time <= '{end}' and b.pay_id = '{pay}'"\
            .format(shop=shop_code,start=start,end=end,pay=pay_id)

    cur.execute(sql)
    List = cur.fetchall()

    for item in List:
        if item['pay_value']:
            item['pay_value'] = float(item['pay_value'])
        else:
            item['pay_value'] = 0

    return render(request, 'report/card/saleGroupByShop/Detail.html', locals())
開發者ID:KGPython,項目名稱:kggroup,代碼行數:52,代碼來源:saleGroupByShop.py

示例5: bestowed

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def bestowed(request):
    s_shop = request.session.get('s_shopcode')
    s_role = request.session.get('s_roleid')
    s_user = request.session.get('s_uid')
    if s_role in ('1', '6'):
        shops = mth.getCityShopsCode()
    elif s_role == '9':
        shops = mth.getCityShopsCode('T')
    elif s_role == '8':
        shops = mth.getCityShopsCode('C')
    elif s_role in ('2', '10'):
        shop = s_shop
    if request.method == 'POST':
        today = str(datetime.date.today())
        start = request.POST.get('start', today)
        end = request.POST.get('end', today)
        end2 = datetime.datetime.strptime(end, '%Y-%m-%d') + datetime.timedelta(1)

        shop= ''
        if s_role in ('1', '6', '8', '9'):
            shop = request.POST.get('shop', '')
        elif s_role in ('2', '10'):
            shop = s_shop
        elif s_role in ('3', '5'):
            shop = s_shop

        kwargs = {}
        kwargs.setdefault('add_time__gte', start)
        kwargs.setdefault('add_time__lte', end2)
        kwargs.setdefault('action_type', '5')
        if shop:
            kwargs.setdefault('shop_code', shop)

        disc_list = Orders.objects.values('disc_amount','shop_code','operator_id','add_time','remark').filter(**kwargs)
        disc_total = 0
        for disc in disc_list:
            disc_total += float(disc['disc_amount'])
    if request.method == 'GET':
        pass
    return render(request, 'report/card/disc/bestowed.html', locals())
開發者ID:KGPython,項目名稱:kggroup,代碼行數:42,代碼來源:disc.py

示例6: index

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def index(request):
    role_id = request.session.get('s_roleid')
    shop = request.session.get('s_shopcode')
    role = request.session.get('s_roleid')
    user = request.session.get('s_uid')

    if request.method == 'POST':
        start = request.POST.get('start','')
        end = request.POST.get('end','')
        endTime = datetime.datetime.strptime(end,'%Y-%m-%d').date() + datetime.timedelta(1)
        whereStr ="WHERE a.add_time >='"+start+"' AND a.add_time <='"+str(endTime)+"' AND a.order_sn = b.order_id "

        if role in ('2','10') :
            whereStr += " AND a.shop_code ='"+shop+"'"
        conn = mth.getMysqlConn()
        cur = conn.cursor()

        shopsCode= ''
        if role_id == '9':
            shopsCode = mth.getCityShopsCode('T')
            shopsCodeStr = "'" + "','".join(shopsCode) + "'"
            whereStr += " AND a.shop_code IN (" + shopsCodeStr + ")"
        if role_id == '8':
            shopsCode = mth.getCityShopsCode('C')
            shopsCodeStr = "'" + "','".join(shopsCode) + "'"
            whereStr += " AND a.shop_code IN (" + shopsCodeStr + ")"

        sql = "SELECT b.pay_id,SUM(b.pay_value) AS pay_value FROM orders as a,order_payment_info as b "+whereStr+" GROUP BY b.pay_id ORDER BY b.pay_id"
        cur.execute(sql)
        payList = cur.fetchall()

        nopay = "SELECT SUM(b.pay_value) AS pay_value FROM orders as a,order_payment_info as b "+whereStr+" AND a.order_sn = b.order_id AND b.is_pay='0' AND b.pay_id=4"

        cur.execute(nopay)
        nopayDict = cur.fetchone()

        payTotal = 0.00
        for row in payList:
            payTotal += float(row['pay_value'])
    return render(request, 'report/card/saleGroupByPay.html', locals())
開發者ID:KGPython,項目名稱:kggroup,代碼行數:42,代碼來源:saleGroupByPay.py

示例7: index

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def index(request):
    shop = request.session.get('s_shopcode')
    role = request.session.get('s_roleid')
    shops = Shops.objects.values('shop_code','shop_name','city').order_by('shop_code')
    if role in ('1','6','7') :
        shops = shops
    elif role == '8':#承德總部財務
        shops = shops.filter(city='C')
    elif role == '9':#唐山總部財務
        shops = shops.filter(city='T')
    else:
        shops = shops.filter(shop_code=shop)
    shops_len = len(shops)
    if request.method == 'POST':
        shopcode = mth.getReqVal(request, 'shopcode', '')
        keyword = mth.getReqVal(request, 'keyword', '')
        # 表單分頁參數開始
        page = mth.getReqVal(request, 'page', 1)
        show_num = mth.getReqVal(request, 'show_num', 8)
        # 表單分頁參數結束

        conn = mth.getMysqlConn()
        cur = conn.cursor()
        whereStr = "WHERE t.is_store = 1 "

        if role in ('2', '10'):
            whereStr += " AND t.shop_code ='" + shop + "'"


        if shopcode != '':
            whereStr += " AND t.shop_code ='" + shopcode + "'"
        else:
            shopsCode = ''
            if role == '9':
                shopsCode = mth.getCityShopsCode('T')
                shopsCodeStr = "'" + "','".join(shopsCode) + "'"
                whereStr += " AND t.shop_code IN (" + shopsCodeStr + ")"
            if role == '8':
                shopsCode = mth.getCityShopsCode('C')
                shopsCodeStr = "'" + "','".join(shopsCode) + "'"
                whereStr += " AND t.shop_code IN (" + shopsCodeStr + ")"

        if keyword != '':
            whereStr += " AND (c.username like '%" + keyword + "%' OR c.`name` like '%" + keyword + "%')"

        sql = """
SELECT
	t.shop_code,
	s.shop_name,
	c.username as user_code,
	IFNULL(c.`name`, '未分配') AS username,
	t.card_value,
	count(t.card_no) AS account,
	sum(CASE WHEN t.card_status = 2 THEN 1 ELSE 0 END) AS out_num,
	sum(CASE WHEN t.card_status = 1 THEN 1 ELSE 0 END) AS in_num
FROM
	card_inventory t LEFT JOIN shops s ON t.shop_code = s.shop_code
	LEFT JOIN cashier_list c ON t.shop_code = c.shop_code and t.username = c.username
"""+ whereStr +"""
GROUP BY
	t.shop_code,
	s.shop_name,
	c.username,
	c.`name`,
	t.card_value
                """
        cur.execute(sql)
        List = cur.fetchall()

        # 表單分頁開始
        paginator = Paginator(List, show_num)

        try:
            List = paginator.page(page)

            if List.number > 1:
                page_up = List.previous_page_number
            else:
                page_up = 1

            if List.number < List.paginator.num_pages:
                page_down = List.next_page_number
            else:
                page_down = List.paginator.num_pages

        except Exception as e:
            print(e)
            # 表單分頁結束

    return render(request, 'consign/list.html', locals())
開發者ID:KGPython,項目名稱:kggroup,代碼行數:92,代碼來源:allocate.py

示例8: getData

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def getData(role_id,shop,start,endTime):
    conn = mth.getMysqlConn()
    cur = conn.cursor()
    if role_id == '1' or role_id == '6':
        shops = mth.getCityShops()
        shopsCode = mth.getCityShopsCode()
    elif role_id == '9':
        shops = mth.getCityShops('T')
        shopsCode = mth.getCityShopsCode('T')
    elif role_id == '8':
        shops = mth.getCityShops('C')
        shopsCode = mth.getCityShopsCode('C')
    elif role_id == '10' or role_id == '2' or role_id == '12' or role_id == '11':
        shops = base.findShop(shop)
        shopsCode = [shop]

    shopsCodeStr = "'" + "','".join(shopsCode) + "'"
    # shopsCodeStr = "('C003')"
    # saleDiscGroupByShop = 'SELECT a.shop_code, SUM(CASE WHEN b.card_balance<= a.diff_price THEN a.y_cash+b.card_balance ELSE a.disc_amount END ) AS disc,' \
    #                       'SUM(a.y_cash) AS disc_cash,SUM(case WHEN b.card_balance<= a.diff_price THEN b.card_balance ELSE b.card_balance-a.diff_price END) AS disc_card ' \
    #                       'FROM orders AS a ' \
    #                       'LEFT JOIN (SELECT  order_id,SUM(card_balance) AS card_balance ' \
    #                       'FROM order_info WHERE card_attr="2" GROUP BY order_id,card_attr) AS b ' \
    #                       'ON b.order_id = a.order_sn ' \
    #                       'WHERE a.add_time >= "{start}" AND a.add_time <= "{end}" AND a.shop_code IN ({shopsCodeStr}) group by a.shop_code '\
    #                      .format(start=start, end=endTime,shopsCodeStr=shopsCodeStr)

    saleDiscGroupByShop = 'select shop_code,' \
                          'SUM(case when disc_amount>=y_cash then disc_amount else diff_price+disc_amount end) as disc, ' \
                          'SUM(y_cash) as disc_cash, ' \
                          'SUM(case when disc_amount>=y_cash then disc_amount-y_cash else disc_amount+diff_price-y_cash end) as disc_card ' \
                          'from orders ' \
                          'where add_time>="{start}" and add_time<="{end}" and shop_code in ({shopsCodeStr}) ' \
                          'group by shop_code ' \
                          .format(start=start, end=endTime, shopsCodeStr=shopsCodeStr)
    cur.execute(saleDiscGroupByShop)
    saleDiscList = cur.fetchall()

    salePayGroupByShop = 'select ord.shop_code,info.pay_id,info.change_time,SUM(info.pay_value) as pay_value ' \
                         'from orders as ord , order_payment_info as info ' \
                         'where ord.add_time>="{start}" and ord.add_time<="{end}" and ord.shop_code in ({shopsCodeStr})' \
                         ' and ord.order_sn = info.order_id ' \
                         'group by ord.shop_code,info.pay_id,info.change_time ' \
                        .format(start=start, end=endTime, shopsCodeStr=shopsCodeStr)
    cur.execute(salePayGroupByShop)
    salePayList = cur.fetchall()

    fillList = OrderUpCard.objects \
        .values('shop_code') \
        .filter(add_time__gte=start, add_time__lte=endTime, shop_code__in=shopsCode) \
        .annotate(fill=Sum('diff_price')) \
        .order_by('shop_code')

    # changeDiscGroupByShop = 'SELECT a.shop_code, SUM(CASE WHEN b.card_balance<= a.disc_pay THEN a.disc_cash+b.card_balance ELSE a.disc END) AS disc,' \
    #                         'SUM(a.disc_cash) AS disc_cash,SUM(case WHEN b.card_balance<= a.disc_pay THEN b.card_balance ELSE b.card_balance-a.disc_pay END) AS disc_card ' \
    #                         'FROM order_change_card AS a '\
    #                         'LEFT JOIN (SELECT  order_sn,sum(card_balance) as card_balance ' \
    #                         'FROM order_change_card_info where type="1" group by order_sn,type)'\
    #                         'AS b on b.order_sn = a.order_sn '\
    #                         'WHERE a.add_time >= "{start}" AND a.add_time <= "{end}" AND a.shop_code IN ({shopsCodeStr}) ' \
    #                         'group by a.shop_code ' \
    #                         .format(start=start, end=endTime,shopsCodeStr=shopsCodeStr)

    changeDiscGroupByShop = 'select shop_code,SUM(case when disc>=disc_cash then disc else disc_pay+disc end) as disc,' \
                            'SUM(disc_cash) as disc_cash,' \
                            'SUM(case when disc>=disc_cash then disc-disc_cash else disc+disc_pay-disc_cash end) as disc_card ' \
                            'from order_change_card ' \
                            'where add_time>="{start}" and add_time<="{end}" and shop_code in ({shopsCodeStr}) ' \
                            'group by shop_code ' \
                            .format(start=start, end=endTime, shopsCodeStr=shopsCodeStr)
    cur.execute(changeDiscGroupByShop)
    changeDiscList = cur.fetchall()
    changePayGroupByShop = 'select ord.shop_code ,info.pay_id,info.change_time,SUM(info.pay_value) as pay_value ' \
                           'from order_change_card as ord , order_change_card_payment as info ' \
                           'where ord.add_time>="{start}" and ord.add_time<="{end}" and shop_code in ({shopsCodeStr}) and ord.order_sn = info.order_id ' \
                           'group by ord.shop_code,info.pay_id,info.change_time' \
                            .format(start=start, end=endTime, shopsCodeStr=shopsCodeStr)
    cur.execute(changePayGroupByShop)
    changePayList = cur.fetchall()

    paymentsRate = Payment.objects.values('id', 'dis_rate').filter(dis_rate__gte=0)
    paymentsRateDict = {item['id']: float(item['dis_rate']) for item in paymentsRate}
    totalDict = {'discTotal': 0,
                 'discCashTotal': 0, 'total_disc_6': 0, 'total_disc_7': 0, 'total_disc_8': 0, 'total_disc_10': 0,
                 'total_disc_11': 0, 'total_disc_qita': 0, 'discCardTotal': 0,
                 'inSubTotal': 0, 'total_1': 0, 'total_2': 0, 'total_3': 0,
                 'total_4': 0, 'total_5': 0, 'total_6': 0, 'total_7': 0, 'total_8': 0, 'total_9': 0, 'total_10': 0,
                 'total_11': 0, }

    dataList = []
    for i in range(0, len(shops)):
        # shopcode = shops[i]['shop_code']
        if shops[i]['shop_code'] != 'ZBTG':
            item = {'shop_code': '',
                    'disc': 0, 'disc_6': 0, 'disc_7': 0, 'disc_8': 0, 'disc_10': 0, 'disc_11': 0, 'disc_cash': 0,
                    'disc_card': 0,
                    'inSub': 0, 'pay_1': 0, 'pay_2': 0, 'pay_3': 0, 'pay_4': 0, 'pay_5': 0, 'pay_6': 0, 'pay_7': 0,
                    'pay_8': 0,
                    'pay_9': 0, 'pay_10': 0, 'pay_11': 0, }
            item['shop_code'] = shops[i]['shop_code']
#.........這裏部分代碼省略.........
開發者ID:KGPython,項目名稱:kggroup,代碼行數:103,代碼來源:saleGroupByShop.py

示例9: index

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def index(request):
    s_shop = request.session.get('s_shopcode')
    s_role = request.session.get('s_roleid')
    s_user = request.session.get('s_uid')
    today = str(datetime.date.today())

    shops = []
    shopsCodeStr = ''
    personList = AdminUser.objects.values('id', 'name','is_enable').filter(role_id__in=('2', '3', '5','11'))
    if s_role in ('1', '6'):
        shops = mth.getCityShopsCode()
        shopsCodeStr = "'" + "','".join(shops) + "'"
        personList = personList.filter(shop_code__in=shops)
    elif s_role == '9':
        shops = mth.getCityShopsCode('T')
        shopsCodeStr = "'" + "','".join(shops) + "'"
        personList = personList.filter(shop_code__in=shops)
    elif s_role == '8':
        shops = mth.getCityShopsCode('C')
        shopsCodeStr = "'" + "','".join(shops) + "'"
        personList = personList.filter(shop_code__in=shops)
    elif s_role in ('2', '10'):
        shop = s_shop
        personList = personList.filter(shop_code=shop)

    personList = sorted(personList, key=lambda p: p["name"].encode('gb2312'))

    if request.method == 'POST':
        shop,operator = '',''
        if s_role in ('1', '6', '8', '9'):
            shop = mth.getReqVal(request, 'shop', '')
            operator = mth.getReqVal(request, 'operator', '')
        elif s_role in ('2', '10'):
            shop = s_shop
            operator = mth.getReqVal(request, 'operator', '')
        elif s_role in ('3', '5'):
            operator = s_user
            shop = s_shop
        start = mth.getReqVal(request, 'start', today)
        end = mth.getReqVal(request,'end',today)
        end2 = datetime.datetime.strptime(end, '%Y-%m-%d') + datetime.timedelta(1)

        #匯總數據
        kwargs ={}
        kwargs.setdefault('add_time__gte',start)
        kwargs.setdefault('add_time__lte',end2)
        if shop:
            kwargs.setdefault('shop_code',shop)
        if operator:
           kwargs.setdefault('operator_id',operator)
        if len(shops)>0:
            kwargs.setdefault('shop_code__in', shops)
        dataTotal = Orders.objects.filter(**kwargs).aggregate(saleTotal=Sum('paid_amount'),discTotal=Sum('disc_amount'))

        #卡麵值列表
        conn = mth.getMysqlConn()
        whereStr = 'ord.order_sn=info.order_id and ord.add_time>= "'+str(start)+'" and ord.add_time<= "'+str(end2)+'" '
        if operator:
            whereStr += ' and operator_id = "'+str(operator)+'" '
        if shop:
            whereStr += ' and ord.shop_code = "'+shop+'"'
        if shopsCodeStr:
            whereStr += ' and ord.shop_code IN (' + shopsCodeStr + ')'
        sqlInfo = 'select ord.shop_code,info.card_balance, count(*) as num from order_info as info,orders as ord ' \
                  'where '+ whereStr+' group by ord.shop_code,info.card_balance'
        cur = conn.cursor()
        cur.execute(sqlInfo)
        dataInfo =cur.fetchall()

    return render(request, 'report/card/saleGroupByCardType.html', locals())
開發者ID:KGPython,項目名稱:kggroup,代碼行數:72,代碼來源:saleGroupByCardType.py

示例10: index

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def index(request):
    role_id = request.session.get('s_roleid')
    s_shop = request.session.get('s_shopcode')
    s_depart = request.session.get('s_depart')
    s_user = request.session.get('s_uid')

    today = str(datetime.date.today())
    start = end = today
    actionType = 1
    shops = []
    users = AdminUser.objects.values('id', 'name','is_enable').filter(role_id__in=('2', '3','5','11'))
    if role_id in ('1','6'):
        shops = mth.getCityShopsCode()
    elif role_id == '9':
        shops = mth.getCityShopsCode('T')
    elif role_id == '8':
        shops = mth.getCityShopsCode('C')
    elif role_id in ('2', '10'):
        shops = [s_shop]
    elif role_id in ('3', '5'):
        shopcode = s_shop
        depart = s_depart
        operator = s_user
    personList = users.filter(shop_code__in=shops)
    personList = sorted(personList, key=lambda p: p["name"].encode('gb2312'))
    departs = base.findDepart()

    if request.method == 'POST':
        shop,operator,depart = '','',''
        if role_id in ('1','6','8','9'):
            shop = request.POST.get('shop','')
            depart = request.POST.get('depart', '')
            operator = request.POST.get('operator', '')
        elif  role_id in ('2','10') :
            shop = s_shop
            depart = request.POST.get( 'depart', '')
            operator = request.POST.get('operator', '')
        elif role_id in ('3','5'):
            shop = s_shop
            depart = s_depart
            operator = s_user
        actionType = request.POST.get('actionType','1')
        start = request.POST.get('start',today)
        end = request.POST.get('end',today)
        endTime = datetime.datetime.strptime(end,'%Y-%m-%d') + datetime.timedelta(1)
        page = request.POST.get('page',1)

        kwargs = {}
        if shop:
            kwargs.setdefault('shop_code',shop)
        if operator:
            kwargs.setdefault('operator_id',operator)
        if depart:
            kwargs.setdefault('depart',depart)
        kwargs.setdefault('add_time__gte',start)
        kwargs.setdefault('add_time__lte',endTime)

        resList, paidTotal, discTotal, cardCount = getData(actionType,kwargs)
        paginator = Paginator(resList,20)
        try:
            resList = paginator.page(page)
            page_next = mth.getNextPageNum(resList)
            page_prev = mth.getPrevPageNum(resList)

        except Exception as e:
            print(e)
    return render(request, 'report/card/saleGroupByOrder/index.html', locals())
開發者ID:KGPython,項目名稱:kggroup,代碼行數:69,代碼來源:saleGroupByOrder.py

示例11: month_pay6

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def month_pay6(request):
    """
    移動積分賒還款
    :param request:
    :return:
    """
    shops = mth.getCityShopsCode()
    if request.method == 'POST':
        postStart = request.POST.get('start')
        if postStart<'2017-01':
            postStart = '2017-01'
        postEnd = request.POST.get('end')

        start = '{postStart}-01 00:00:00'.format(postStart=postStart)
        endTemp = datetime.datetime.strptime(postEnd,'%Y-%m')
        if endTemp.month == 12:
            end = datetime.datetime(endTemp.year+1, 1, 1)
        else:
            end = datetime.datetime(endTemp.year, endTemp.month + 1, 1)

        shop_code = request.POST.get('shop','')
        parameterShop = '1=1'
        parameterShop2 = '1=1'
        if shop_code:
            parameterShop = 'shop="{shop}"'.format(shop=shop_code)
            parameterShop2 = 'shop_code="{shop}"'.format(shop=shop_code)

        conn = mth.getMysqlConn()
        cur = conn.cursor()

        #在起始日期之前賒銷,在起始日期之前未到賬
        sqlBeforeNoPay = ' select sum(b.pay_value) as total' \
                         ' from orders as a, order_payment_info as b' \
                         ' where a.add_time>="2017-01-01 00:00:00" and a.add_time<="{start}" and {shop}' \
                         ' and b.pay_id =6 and a.order_sn = b.order_id' \
                        .format(start=start,shop=parameterShop2)
        cur.execute(sqlBeforeNoPay)
        beforeNoPay = cur.fetchone()
        totalNoPayBefore = beforeNoPay['total']
        totalNoPayBefore = totalNoPayBefore if totalNoPayBefore else 0
        #在起始日期之前賒銷,在起始日期之後到賬
        sqlBeforePaid = 'select sum(b.pay_value) as total' \
                        ' from order_payment_credit as b,orders as a ' \
                        ' where a.order_sn=b.order_id and a.add_time>="2017-01-01 00:00:00" and a.add_time<="{start}"' \
                        ' and b.change_time<="{start}" and {shop} and b.pay_id_old =6' \
                        .format(start=start, end=end, shop=parameterShop2)
        cur.execute(sqlBeforePaid)
        beforePaid = cur.fetchone()
        totalPaidBefore = beforePaid['total']
        totalPaidBefore = totalPaidBefore if totalPaidBefore else 0
        #曆史累計
        totalNoPayBefore = totalNoPayBefore - totalPaidBefore

        #賒出記錄
        sqlNoPay =' select a.shop_code as shop,DATE_FORMAT(a.add_time,"%Y-%m") as add_time,SUM(b.pay_value) as pay_value,0 as is_pay' \
                  ' from orders as a,order_payment_info as b' \
                  ' where a.add_time>="2017-01-01 00:00:00" and a.add_time>="{start}" and a.add_time<="{end}" and {shop}' \
                  ' and b.pay_id =6 and a.order_sn = b.order_id' \
                  ' GROUP BY a.shop_code,DATE_FORMAT(a.add_time,"%Y-%m")'\
            .format(start=start, end=end,shop=parameterShop2)
        cur.execute(sqlNoPay)
        noPayList = cur.fetchall()
        #還款記錄
        sqlPaid = ' select shop,DATE_FORMAT(change_time,"%Y-%m") as change_time,sum(pay_value) as pay_value,1 is_pay' \
                  ' from order_payment_credit ' \
                  ' where change_time>="2017-01-01 00:00:00" and change_time>="{start}" and change_time<="{end}"' \
                  ' and {shop} and pay_id_old=6' \
                  ' GROUP BY shop,DATE_FORMAT(change_time,"%Y-%m")'.format(start=start, end=end,shop=parameterShop)
        cur.execute(sqlPaid)
        paidList = cur.fetchall()
        noPayList = splitDataPay6('0', noPayList, start, end)
        paidList = splitDataPay6('1', paidList, start, end)
        dataSelect = noPayList + paidList
        totalNoPay = float(totalNoPayBefore)
        if len(dataSelect) > 0:
            dataSorted = sorted(dataSelect, key=itemgetter('time'), reverse=False)
            totalPay, MonthNoPay, MonthPay, index, = 0, 0, 0, 0
            resData, monthSubTimeList = [], []

            for row in dataSorted:
                rowTimeNow = datetime.datetime.strptime(row['time'],'%Y-%m')
                if index == 0:
                    rowTimePre =rowTimeNow
                else:
                    rowTimePre = dataSorted[index - 1]['time']
                    rowTimePre = datetime.datetime.strptime(rowTimePre,'%Y-%m')
                if isNextMonth(rowTimeNow, rowTimePre):
                    yesterday = datetime.datetime(rowTimeNow.year, rowTimeNow.month, 1) + datetime.timedelta(days=-1)
                    if yesterday not in monthSubTimeList:
                        startDate = datetime.datetime.strptime(start, '%Y-%m-%d %H:%M:%S')
                        if yesterday >= startDate:
                            monthSubitem = MonthSub(MonthPay, MonthNoPay, yesterday.date())
                            resData.append(monthSubitem)
                            monthSubTimeList.append(yesterday)
                            MonthNoPay = 0
                            MonthPay = 0
                if 'is_pay' in row:
                    if row['is_pay'] == '1':
                        MonthPay += float(row['pay'])
                        totalPay += float(row['pay'])
#.........這裏部分代碼省略.........
開發者ID:KGPython,項目名稱:kggroup,代碼行數:103,代碼來源:noPay.py

示例12: month_pay4

# 需要導入模塊: from sellcard.common import Method [as 別名]
# 或者: from sellcard.common.Method import getCityShopsCode [as 別名]
def month_pay4(request):
    """
    :param request:
    :return:
    """
    shops = mth.getCityShopsCode()
    if request.method == 'POST':
        postStart = request.POST.get('start')
        if postStart<'2017-06':
            postStart = '2017-06'
        postEnd = request.POST.get('end')

        start = '{postStart}-01 00:00:00'.format(postStart=postStart)
        endTemp = datetime.datetime.strptime(postEnd,'%Y-%m')
        if endTemp.month == 12:
            end = datetime.datetime(endTemp.year+1, 1, 1)
        else:
            end = datetime.datetime(endTemp.year, endTemp.month + 1, 1)

        shop_code = request.POST.get('shop','')
        parameterShop = '1=1'
        if shop_code:
            parameterShop = 'a.shop_code="{shop}"'.format(shop=shop_code)

        conn = mth.getMysqlConn()
        cur = conn.cursor()

        #在起始日期之前賒銷,在起始日期之前未到賬
        sqlBeforeNoPay = 'select sum(b.pay_value) as total from orders as a, order_payment_info as b' \
                         ' where a.add_time>="2017-06-01 00:00:00" and a.add_time<="{start}" and {shop}' \
                         ' and b.pay_id =4 and is_pay=0 and a.order_sn = b.order_id' \
                        .format(start=start,shop=parameterShop)
        cur.execute(sqlBeforeNoPay)
        beforeNoPay1 = cur.fetchone()
        totalNoPayBefore1 = beforeNoPay1['total']
        totalNoPayBefore1 = totalNoPayBefore1 if totalNoPayBefore1 else 0
        #在起始日期之前賒銷,在起始日期之後到賬
        sqlBeforeNoPay2 = 'select sum(b.pay_value) as total' \
                          ' from order_payment_credit as b LEFT JOIN orders as a ON b.order_id = a.order_sn' \
                          ' where a.add_time>="2017-06-01 00:00:00" and a.add_time<="{start}"' \
                          ' and b.change_time>="{start}" and {shop} and b.pay_id_old =4' \
                          .format(start=start, end=end, shop=parameterShop)
        cur.execute(sqlBeforeNoPay2)
        beforeNoPay2 = cur.fetchone()
        totalNoPayBefore2 = beforeNoPay2['total']
        totalNoPayBefore2 = totalNoPayBefore2 if totalNoPayBefore2 else 0
        #曆史累計
        totalNoPayBefore = totalNoPayBefore1 +totalNoPayBefore2

        #賒出記錄
        sqlNoPay =' select a.order_sn,a.buyer_company,a.shop_code,a.add_time,b.pay_id ,b.pay_value' \
                  ' from orders as a,order_payment_info as b' \
                  ' where a.add_time>="2017-06-01 00:00:00" and a.add_time>="{start}" and a.add_time<="{end}" and {shop}' \
                  ' and b.pay_id =4 and a.order_sn = b.order_id' \
                  ' order by a.add_time'.format(start=start, end=end,shop=parameterShop)
        cur.execute(sqlNoPay)
        noPayList = cur.fetchall()
        #還款記錄
        sqlPaid = ' select a.order_sn,a.shop_code,b.pay_company,b.change_time,b.pay_id ,b.pay_value' \
                  ' from order_payment_credit as b LEFT JOIN orders as a' \
                  ' ON b.order_id = a.order_sn' \
                  ' where a.add_time>="2017-06-01 00:00:00" and b.change_time>="{start}" and {shop}' \
                  ' and b.change_time<="{end}" and b.pay_id_old=4' \
                  ' order by b.change_time'.format(start=start, end=end,shop=parameterShop)
        cur.execute(sqlPaid)
        paidList = cur.fetchall()

        noPayList = splitData('0',noPayList,start,end)
        paidList = splitData('1',paidList,start,end)
        dataSelect = noPayList + paidList
        totalNoPay = float(totalNoPayBefore)
        if len(dataSelect)>0:
            dataSorted = sorted(dataSelect, key=itemgetter('time'), reverse=False)
            totalPay,MonthNoPay,MonthPay,index, = 0,0,0,0
            resData,monthSubTimeList = [],[]

            for row in dataSorted:
                if index == 0:
                    rowTimePre = rowTimeNow
                else:
                    rowTimeNow = row['time']
                    rowTimePre = dataSorted[index-1]['time']
                if isNextMonth(rowTimeNow,rowTimePre) and (row['time'].date()+datetime.timedelta(days=-1) not in monthSubTimeList):
                    time = datetime.datetime(rowTimeNow.year,rowTimeNow.month,1)+datetime.timedelta(days=-1)
                    if time>=datetime.datetime.strptime(start,'%Y-%m-%d %H:%M:%S'):
                        monthSubitem = MonthSub(MonthPay,MonthNoPay,time)
                        resData.append(monthSubitem)
                        monthSubTimeList.append(time)
                        MonthNoPay = 0
                        MonthPay = 0
                if 'is_pay' in row:
                    if row['is_pay'] == '1':
                        MonthPay += float(row['pay'])
                        totalPay += float(row['pay'])
                        totalNoPay += -float(row['pay'])
                        row['sub'] = totalNoPay
                    else:
                        MonthNoPay += float(row['noPay'])
                        totalNoPay += float(row['noPay'])
                        row['sub'] = totalNoPay
#.........這裏部分代碼省略.........
開發者ID:KGPython,項目名稱:kggroup,代碼行數:103,代碼來源:noPay.py


注:本文中的sellcard.common.Method.getCityShopsCode方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。