Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
F
ffm-baseline
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
ML
ffm-baseline
Commits
ffefbc57
Commit
ffefbc57
authored
Oct 19, 2018
by
张彦钊
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
增加rank01对应的统计脚本
parent
92f34ce0
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
97 additions
and
0 deletions
+97
-0
rank01_ctr.py
rank01_ctr.py
+97
-0
No files found.
rank01_ctr.py
0 → 100644
View file @
ffefbc57
# -*- coding: UTF-8 -*-
import
pymysql
import
datetime
import
pandas
as
pd
def
get_yesterday_date
():
today
=
datetime
.
date
.
today
()
yesterday
=
today
-
datetime
.
timedelta
(
days
=
1
)
yesterday
=
yesterday
.
strftime
(
"
%
Y-
%
m-
%
d"
)
print
(
yesterday
)
return
yesterday
def
get_data
():
conn2db
=
pymysql
.
connect
(
host
=
'10.66.157.22'
,
port
=
4000
,
user
=
'root'
,
passwd
=
'3SYz54LS9#^9sBvC'
,
db
=
'eagle'
)
cursor
=
conn2db
.
cursor
()
sql
=
"select device_id from ffm_diary_queue_temp where device_id regexp '[5|6]$'"
cursor
.
execute
(
sql
)
result
=
cursor
.
fetchall
()
device
=
tuple
(
pd
.
DataFrame
(
list
(
result
))[
0
]
.
values
.
tolist
())
cursor
.
close
()
print
(
device
[
0
:
2
])
return
device
def
ctr_all
():
db
=
pymysql
.
connect
(
host
=
'10.66.157.22'
,
port
=
4000
,
user
=
'root'
,
passwd
=
'3SYz54LS9#^9sBvC'
,
db
=
'jerry_prod'
)
cursor
=
db
.
cursor
()
sql_active
=
"select distinct device_id from data_feed_exposure "
\
"where cid_type = 'diary' and device_id regexp'[5|6]$' and stat_date = '{}';"
.
format
(
date
)
cursor
.
execute
(
sql_active
)
result
=
cursor
.
fetchall
()
tail56
=
pd
.
DataFrame
(
list
(
result
))[
0
]
.
values
.
tolist
()
print
(
"当天尾号5或6活跃用户总数:"
)
print
(
len
(
tail56
))
cover
=
len
(
set
(
tail56
)
&
set
(
device_id
))
print
(
"当天尾号5或6活跃用户覆盖数:"
)
print
(
cover
)
cover_percent
=
format
(
cover
/
len
(
tail56
),
".3f"
)
print
(
"当天尾号5或6活跃用户覆盖率:"
)
print
(
cover_percent
)
sql_click
=
"select count(cid) from data_feed_click "
\
"where (cid_type = 'diary' or cid_type = 'diary_video') "
\
"and stat_date = '{}' and device_id regexp '[5|6]$';"
.
format
(
date
)
cursor
.
execute
(
sql_click
)
click
=
cursor
.
fetchone
()[
0
]
print
(
"点击数:"
+
str
(
click
))
sql_exp
=
"select count(cid) from data_feed_exposure "
\
"where (cid_type = 'diary' or cid_type = 'diary_video') and stat_date = '{}' and "
\
"device_id regexp '[5|6]$'"
.
format
(
date
)
cursor
.
execute
(
sql_exp
)
exp
=
cursor
.
fetchone
()[
0
]
print
(
"曝光数:"
+
str
(
exp
))
print
(
"点击率:"
+
str
(
click
/
exp
))
return
len
(
tail56
),
cover
,
cover_percent
,
click
,
exp
,
format
(
click
/
exp
,
".6f"
)
def
ctr
():
sql_click
=
"select count(cid) from data_feed_click "
\
"where (cid_type = 'diary' or cid_type = 'diary_video') "
\
"and stat_date = '{}' and device_id in {};"
.
format
(
date
,
device_id
)
db
=
pymysql
.
connect
(
host
=
'10.66.157.22'
,
port
=
4000
,
user
=
'root'
,
passwd
=
'3SYz54LS9#^9sBvC'
,
db
=
'jerry_prod'
)
cursor
=
db
.
cursor
()
cursor
.
execute
(
sql_click
)
click
=
cursor
.
fetchone
()[
0
]
print
(
"实验用户点击数:"
+
str
(
click
))
sql_exp
=
"select count(cid) from data_feed_exposure "
\
"where (cid_type = 'diary' or cid_type = 'diary_video') and stat_date = '{}' and "
\
"device_id in {}"
.
format
(
date
,
device_id
)
cursor
.
execute
(
sql_exp
)
exp
=
cursor
.
fetchone
()[
0
]
print
(
"实验用户曝光数:"
+
str
(
exp
))
print
(
"实验用户点击率:"
+
str
(
click
/
exp
))
return
click
,
exp
,
format
(
click
/
exp
,
".6f"
)
def
rate2file
():
output_path
=
DIRECTORY_PATH
+
"56ctr.csv"
with
open
(
output_path
,
'a+'
)
as
f
:
line
=
date
.
replace
(
'-'
,
''
)
+
','
+
str
(
temp_data
[
0
])
+
','
+
str
(
temp_data
[
1
])
+
','
+
str
(
temp_data
[
2
])
+
\
","
+
str
(
data
[
0
])
+
","
+
str
(
data
[
1
])
+
","
+
str
(
data
[
2
])
+
","
+
str
(
data
[
3
])
+
","
+
str
(
data
[
4
])
\
+
","
+
str
(
data
[
5
])
+
'
\n
'
f
.
write
(
line
)
if
__name__
==
"__main__"
:
DIRECTORY_PATH
=
"/data2/ffm/"
date
=
get_yesterday_date
()
device_id
=
get_data
()
temp_data
=
ctr
()
data
=
ctr_all
()
rate2file
()
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment