Excel—工作常用
上周起始日期
=TODAY()-WEEKDAY(TODAY(),2)-6
TODAY()表示的是当天的日期,WEEKDAY(TODAY(),2)表示本周的星期几,TODAY()-WEEKDAY(TODAY(),2)这段公式算出了上一周的最后一天,-6就变成了上一周的第一天。
上周结束日期
=TODAY()-WEEKDAY(TODAY(),2)
和上周起始日期基本一样,就是后面不用减6了,因为前面的那段公式正好算出本周的结束日期。
上一年的同期周开始日期和结束日期
=DATE(YEAR(XXXXXXX)-1,MONTH(XXXXXXX),DAY(XXXXXXX))
以上两个函数表示的当年的上一周的起始和结束日期,如果要算出上一年的同期日期需要引用本年上周开始和结束日期的单元格
上一年同期的周结束日期公式是=YEAR(XXXXXXX)-1&"-"&MONTH(XXXXXXX)&"-"&DAY(XXXXXXX),其中XXXXXXX就是引用的单元格(上周的结束日期),就相当于把本年的本周结束日期年的部分减了1,月和日都不变,直接引用过来
而上一年的同期的周开始日期公式是=YEAR(XXXXXXX)-1&"-"&MONTH(XXXXXXX)&"-"&DAY(XXXXXXX),其中XXXXXXX就是引用的单元格(上周的开始日期),和上面一样,或是也可以直接引用上一年的周结束日期的单元格然后减6,结果是一样的。
调取一段日期的函数公式
=CUBESET("SYRetail","{[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"]:[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"]}",TEXT(XXXXXXX,"YY.MM.DD")&"-"&TEXT(XXXXXXX,"MM.DD"))
=CUBESET("SYRetail","{[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"]:[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"]}",TEXT(XXXXXXX,"YYYY.MM.DD")&"—"&TEXT(XXXXXXX,"YYYY.MM.DD"))
通过上面的几个公式,我们得到了4个日期,分别是本年的上周开始和结束日期,和上一年的上周开始和结束日期,如果把一段日期写在一个单元格(就是要在一个单元格写出一个日期区间),我们可以用到下面这段公式
CUBESET表示引用数据源的一段区域,这里我们要的是一段日期,SYRetail是我们数据源的名称,固定的,敲出CUBESET函数,打出双引号是会自动出来这个数据源名称的。
"{[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"]:[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"]}" 这段函数表示的是我要取一段日期,然后它的开始日期样式和值是&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"],
:表示是到的意思
:前面的是起始日期,后面是结束日期,注意引用的单元格,第一处XXXXXXX是引用的开始日期,第二处XXXXXXX是引用的结束日期。
另外 "{[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"]:[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"]}", 注意这整段函数的符号,首先要取一段的值,那就一定会用到一个大括号{}相当于数组,然后链接的日期样式也都是成对出现的。&["& &"]。这里TEXT函数是将数字转化成文本,因为数据源中的日期都是文本的形式,不转换一下是调取不到数值的。把要的这段日期区间以什么形式呈现出来,同理因为以后要直接引用这段日期区间,所以要把这段日期转换为文本,
公式是 TEXT(XXXXXXX,"YY.MM.DD")&"-"&TEXT(XXXXXXX,"MM.DD"),这段公式很好理解,唯一要注意的就是中间区分两个日期的符号表现形式,这里用的是 - 但是俩个日期中间加了这么多&"-"&,这里注意一下。
本月起始日期
=DATE(YEAR(XXXXXXX),MONTH(XXXXXXX),DAY(1))
DATE可以得到一个日期函数,里面有3个函数,分别表示的是年、月、日,因为要表示本月的起始日期,day参数就固定写成“1”就好了,而这里面的两个XXXXXXX都是引用的同一个单元格,就是当天日期。
方法二(不建议使用,逻辑容易了)
=EOMONTH(XXXXXXX,-1)+1
XXXXXXX是引用单元格(引用的是本年本周的结束日期),EOMONTH是表示指定日期月份的之前或之后的最后一天函数,第二个参数就是表示前面的月份最后一天还是,后面的月份最后一天,例如我要引用的单元格日期是2017-07-07,那么我第二参数要是写-1就会得到2017-06-30,如果是1就会得到2017-08-31,如果是2就会得到2017-09-30。而在我们要得出的是本月的起始日期,那么我们引用下本年上周的结束日期,用它得到上个月的最后一天,然后在加上1,就巧妙的得到了本月的起始日期。
本月结束日期
=DATE(YEAR(XXXXXXX),MONTH(XXXXXXX)+1,DAY(1))-1
DATE可以得到一个日期函数,里面有3个函数,分别表示的是年、月、日。XXXXXXXX都是引用的同一个单元格,就是当天日期。MONTH加1表示的是下个月的月份,day参数用“1”代表1号,DATE(YEAR(XXXXXXX),MONTH(XXXXXXX)+1,DAY(1))这段公式代表的是下月的1号,然后在这段公式后面再减掉一个1,就得到了本月的月末日期。
由于工作需要,为了直观可以写成 =TODAY() 表示的是当天的日期
年的起始日期
=DATE(YEAR(XXXXXXX),MONTH(1),DAY(1))
XXXXXXX引用的是当天日期,MONTH和DAY参数都写的是1,表示1月1号。
本年的结束日期
=DATE(YEAR(XXXXXXX)+1,MONTH(1),DAY(1))-1
XXXXXXX引用的是当天的日期,DATE(YEAR(XXXXXXX)+1,MONTH(1),DAY(1))表示明年的1月1号,后面再减掉个1就得到了本年的结束日期。
由于工作需要,为了直观可以写成 =TODAY() 表示的是当天的日期
调取数据源中的某个条件
(说白了就是我要某个单元格呈现数据源的条件,为了我做表可以直接引用,但是手写的文本和数值当单元格引用条件时是不能调用的,也会报错,所以我们要引用的单元格内的数值或是文本必须是由公式代入进去的)
比如
调取一个日期的函数公式
=CUBEMEMBER("SYRetail","[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-MM-dd")&"]")
CUBEMEMBER表示调取某一个条件,"SYRetail"是数据源,固定格式,"[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-MM-dd")&"]"是调取的内容,前半段[日期].[日期]表示数据源的内容,&["&TEXT(XXXXXXX,"yyyy-MM-dd")&"]表示引用的条件所呈现的样式。
这个公式里面有一个单元格引用,引用的是你想要调取的日期,虽然这个日期是手写的,但是也要注意格式“0000-00-00”
调取一段日期的函数公式
=CUBESET("SYRetail","{[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"]:[日期].[日期].&["&TEXT(XXXXXXX,"yyyy-mm-dd")&"]}",TEXT(XXXXXXX,"YY.M.DD")&"-"&TEXT(XXXXXXX,"M.DD"))
这里一共4处需要引用单元格,1和3处是引用开始日期的,2和4处引用的是结束日期的
调取同比日期的公式
=CUBEMEMBERPROPERTY("SYRetail",XXXXXXX,"对比日期")
引用的单元格是本年的日期,得到的是去年的同比日期(比如2018-05-10这个日期得到的同比日期是2017-05-11日,具体算法暂时不清楚,有可能是根据节日日期人为更改的)
调取店铺编码的函数公式
=CUBEMEMBER("SYRetail","[机构].[店铺代码].&["&XXXXXXX&"]")
其中XXXXXXX是表示引用的单元格,而这个单元格的内容就是店铺编码,但不是公式性的,我们没法直接嵌套函数。就相当于我们插了一列辅助列,然后用这个公式调取一列带有公式的“店铺名称”,这样我们就可以直接当条件来调取BI中的数据了。
调取店铺名称的函数公式(很少用到,一般都用店铺代码来做辅助列)
=CUBEMEMBER("SYRetail","[机构].[店铺].&["&XXXXXXX&"]")
其中XXXXXXX是表示引用的单元格,而这个单元格的内容就是店铺名称,但不是公式性的,我们没法直接嵌套函数。就相当于我们插了一列辅助列,然后用这个公式调取一列带有公式的“店铺名称”,这样我们就可以直接当条件来调取BI中的数据了。
调取一段值的函数公式
=CUBEVALUE("SYRetail",XXXXXXX,XXXXXXX,XXXXXXX。。。)
通过上面的几个公式我们现在可以从数据源调取了一些条件,而下面这个函数就可以使我们利用这些条件找到相应的值,比如自营区5月1号到5号的销售金额是多少
CUBEVALUE是调用数据源中多条件的值的函数,"SYRetail"数据源名称固定格式,后面的参数分别是引用的条件,每个引用的单元格都是一个条件,中间用逗号隔开,可以写无限个条件,注意这些条件是并且的关系。
(比如18年5月1日的童装分公司的销售金额,就需要引用3个单元格,“童装”,“2018-05-01”,“销售金额”。引用的顺序无所谓)
周会报表说明
一.大围销售数据
销售金额,三个参数维度(1.时间或时间段 2.区域或整个自营区 3.销售金额(固定的公式,目的直接调用)),一般都是反应和去年的同比,所以销售金额参数是固定的,不同情况会用两个变量参数,一个是时间,一个是区域。
二.原店销售数据(店铺属性有更新时,就是大围店和原店有变化时,需要更新表格)
提到原店的销售数据就一定要先制作一个表格,不能直接在BI里面调用,因为BI中是无法区分原店和大围店的,制作的这个表是要利用实时更新的店铺属性表,然后在区分好的店铺属性表里面做销售数据,同样加入三个参数维度,(1.时间或时间段 2.区域或整个自营区 3.销售金额(固定的公式,目的直接调用)),最后把做好的数据利用sumifs函数引用到新的表格中,这样就可以把原店的分出来了。
三.大围出货数据(需要每周手动更新)需要到配货系统里面调取上一周的数据,每周都要填数据
出货数据(又叫发货数据)要到配货系统里面调取数据,可以取一天的也可以取一个时间段的,但是只可以统计昨天前的,当天的数据不准确!调取的出货数据是以款号区分的。我们要统计的表是以18年季度统计的,但是调取的数据不单单有18年的,还有其他的年份季节和配衬,所以我们要利用IFERROR和VLOOKUP函数加入一列辅助列,来区分18年的春夏秋冬季和其他季度的。统计的金额也是结算后的金额(就是折后价)。
四.大围折扣数据
大围折扣数据和大围销售数据一样都可以直接到BI数据源里面直接调取你们的数值,三个参数(1.时间或时间段 2.区域或自营区 3.销售折扣率(折扣率=实际销售金额/吊牌价))
五.原店毛利数据(店铺属性有更新时,就是大围店和原店有变化时,需要更新表格)
要算毛利一定要调取2个参数,一个是销售金额一个是吊牌金额
原店!!!依然要制作表格,然后引用表格中的数据做表。要用的sumifs函数。做这个表格之前要调取销售金额和吊牌金额的数据,可以直接利用公式引用。
这里有几个公式:
毛利额=销售金额(实际成交金额)*毛利率
毛利率=(销售折扣率-进货折扣率)/销售折扣率 这里的销售折扣率是指的实际销售折扣率,而进货折扣一般都是0.55
销售折扣率=实际销售金额/吊牌金额
六.大围售出数据
售出率可以直接引用BI公式,但是这里又延伸一个概念,售出率分为发货售出率和订单售出率
发货售出率=报表系统销售数量/配货系统出货数量
订单售出率=报表系统销售数量/订单系统原始订单数量
一年4个季度,订货会一般是在3、6、9、12月份,订单数量是订货会订购的数量,如果后期涉及到加单了就要算出货数量了,一般每个季度在前一个半月我们算的是订单售出率,因为很少有加单的,在每个季度的后一个半月我们一般就算发货售出率了,因为会有一些加单的。
七.大围库存数据(这个表也是需要每周手动更新的)
库存也是需要到配货系统里面调取数据的,需要做几列辅助列,首先是实际库存,实际的库存需要刨除掉负值和B仓的库存,负值是厂家欠我们库房的货品,B仓是次品仓。(还要把配衬和其他季节区分开)
每次统计的时候需要把上一次的数据保存下来,也就是上周的数据,把上周的数据放到大上周,然后和上周的数据做比较。
我们一共7个仓,每个仓的含义:
A仓(是总仓,就是总厂发来的货物首先要进到总仓,然后从总仓往各个分仓发货)
B仓(次品仓,所有的次品都会放到次品仓)
E仓(自营仓,就是我们自营店铺的货品存放处)
F仓(童装仓,所有的童装都是放到这个仓库的,包括客户的童装和自营的童装)
T仓(原来是田峰仓,现在也算自营仓了)
Y仓(客户仓,所有的客户货品会放到这个仓)
Z仓(快单仓,就是我们自己加单的货都会进到这个仓,有时候我们自己觉得卖的好的货品也会进点,到时候推给客户或自己消化)
八.导入图片(通过款号导入图片)
操作方法:
1.选中需要插入图片的行或列首个单元格,然后选择“视图”选项卡中的“宏”,然后输入一个名字(英文组成),点击创建。
进入到公式编写栏,将之前的代码全部清除掉
把下面这段公式复制到代码编写栏,注意修改5处代码,下方已用颜色标注。
Sub 清空图片()
'删除当前sheet上所有的图片文件
For Each Shape In ActiveSheet.Shapes
Shape.Delete
Next
End Sub
Sub 插入图片()
FilePath = "E:\商品图片\" '图片文件路径
Fill = 0 '插入方式:1:按列插入图片(横向) , 0 按行插入图片(纵向)
Row = 6 '款号所在的行数
col = 42 '款号所在的列数
Location = -1 ' 1: 图片在款号右边或下面 , -1 : 图片在款号左边或上面
Do
'根据第一行的图片文件名,将图片插入在第二行内,并调整图片的高与宽
With Cells(Row + IIf(Fill = 1, Location, 0), col + IIf(Fill = 0, Location, 0))
.Select
L = .Left
T = .Top
W = .Width
H = .Height
Filename = Cells(Row, col).Text & ".jpg" '生成文件名
If Filename = ".jpg" Then '如果1行为空,表示结束
Exit Do
End If
If Dir(FilePath & Filename) <> "" Then '检查文件存在
'插入图片
ActiveSheet.Shapes.AddShape(1, L, T, W, H).Fill.UserPicture (FilePath & Filename)
End If
End With
If Fill = 1 Then
col = col + 1
Else
Row = Row + 1
End If
Loop
Cells(1, 1).Select '回到A1单元格
End Sub
总结
1.如果要统计原店数据,那么一定要重新制作表格,要引用店铺属性的汇总表,不能直接引用BI数据源,因为BI数据源是没法区分原店和大围店的
2.若是要统计出货(发货)和库存的数据,需要到配货系统里面调取数据,BI的数据不准确,出货(发货)起始日期和结束日期都可以选择(可以选择单独一天或一个时间段),库存则只有一个时间段,库存是实时数据,是截至现在库存的数据。
Excel—工作常用的更多相关文章
- Excel工作常用(一)-生成序列与删除空行
整理一些工作中,本人经常用到的一些Excel操作 1.自动生成序列 [注]选择 第一格 和 第二格 之后,在右下角出现十字的时候,在往下拉 2.删除空行 方式一,先找出所有空行,在删 [缺点]数据多的 ...
- C#7.2——编写安全高效的C#代码 c# 中模拟一个模式匹配及匹配值抽取 走进 LINQ 的世界 移除Excel工作表密码保护小工具含C#源代码 腾讯QQ会员中心g_tk32算法【C#版】
C#7.2——编写安全高效的C#代码 2018-11-07 18:59 by 沉睡的木木夕, 123 阅读, 0 评论, 收藏, 编辑 原文地址:https://docs.microsoft.com/ ...
- 如何使用 Visual C# 2005 或 Visual C# .NET 向 Excel 工作簿传输数据
本文分步介绍了多种从 Microsoft Visual C# 2005 或 Microsoft Visual C# .NET 程序向 Microsoft Excel 2002 传输数据的方法.本文还提 ...
- 读写 Excel 工作表
导入诸如 CSV 之类文本格式的数据的优点是不需要依靠某些特定软件来读取数据,并且文件具有可读性,即软件中性.然而,它的缺点也很明显——我们不能直接对文本编辑器中的数据执行计算操作,因为这些内容是纯文 ...
- VBA基础之Excel 工作薄(Book)的操作(三)
三. Excel 工作薄(Book)的操作1. Excel 创建工作薄(Book) Sub addWorkbook() Workbooks.Add End Sub 2. Excel 打开工作薄(Boo ...
- 个人永久性免费-Excel催化剂功能第27波-Excel工作表设置快捷操作
Excel催化剂在完善了数据分析场景的插件需求后,决定再补充一些日常绝大多数Excel用户同样可以使用到的小功能,欢迎小白入场,在不违背太多Excel最佳实践的前提下,Excel催化剂乐意为广大Exc ...
- 思迈特软件Smartbi:Excel数据分析常用函数汇总!
多传统行业的数据分析师只要求掌握Excel即可,会SPSS/SAS是加分项.即使在挖掘满街走,Python不如狗的互联网数据分析界,Excel也是不可替代的. Excel是我们工作中经常使用的一种工具 ...
- C#中如何在Excel工作表创建混合型图表
在进行图表分析的时候,我们可能需要在一张图表呈现两个或多个样式的图表,以便更加清晰.直观地查看不同的数据大小和变化趋势.在这篇文章中,我将分享C#中如何在一张图表中创建不同的图表类型,其中包括如何在同 ...
- C#将一个excel工作表根据指定范围拆分为多个excel文件
C#将一个excel工作表根据指定范围拆分为多个excel文件 微软Excel没有提供直接的方法来拆分excel文件,因此要拆分一个excel文件最简单的方法可能就是手动剪切和粘贴了,除此之外,还有其 ...
随机推荐
- IDEA的Tomcat的几个坑。
IDEA乱码的解决. Tomcat配置完成后打开IDEA可能会出现控制台乱码,如下. 解决方法如下: 首先设置Tomcat在配置项VM options文本框中输入-Dfile.encoding=UTF ...
- Httpclient发送json请求
一.Httpclient发送json请求 public String RequestJsonPost(String url){ String strresponse = null; try ...
- HBase LSM树存储引擎详解
1.前提 讲LSM树之前,需要提下三种基本的存储引擎,这样才能清楚LSM树的由来: 哈希存储引擎. B树存储引擎. LSM树(Log-Structured Merge Tree)存储引擎. 2. 哈希 ...
- http和https协议的区别
内容摘自:转载注明Wosign 尊重知识产权 一 什么是HTTPS HTTPS全称为 安全超文本传输协议(Secure Hypertext Transfer Protocol)),是一个安全通信通道, ...
- 一秒钟带你走进P图世界-----(python)PIL库的使用
python-----PIL库的使用 一.什么是PIL库 1.PIL(Python Image Library)库是python语言的第三方库,具有强大的图像处理能力,不仅包含了丰富的像素.色彩操作功 ...
- shell 生成文件统计信息
#!/bin/bash #file name : filestat.sh if [ $# -ne 1 ]; then echo "Usage is $0 basepath"; ex ...
- es6中的class的使用
---恢复内容开始--- es5中生成实例对象的传统方法是通过构造函数: function Point(x,y){ this.x = x; this.y = y; } Point.prototype. ...
- JavaScript之Map对象
前言 工欲善其事,必先利其器.这是一款以前在前端项目中没有使用过的.有趣的对象,咱来看看如何使用~ 并非arrayObj.map(function) //arrayObj.map与arrayObj.f ...
- java abs(绝对值) , max(最大值),min(最小值) 方法的应用
在写程序是,我们常常会计算一个数的绝对值,这时我们可以使用java里的方法来计算 public class Demo1{ public static void main(String [] args) ...
- JAVA进阶20
1.可视化日历程序(简陋版) package cn.zh.abstrac; import java.text.DateFormat; import java.text.ParseException; ...